Ruby on Rails
Thursday, July 26, 2018
Thanks
On Fri, Jul 27, 2018 at 9:56 AM, Walter Lee Davis <waltd@wdstudio.com> wrote:
Sure. In the main application.html.erb of your site, you should see this line somewhere in the <head>:
<%= javascript_include_tag 'application', 'data-turbolinks-track': 'reload' %>
If you don't, then that's because you moved it into a partial (called rails_defaults, maybe -- that's what I recall from your first post).
You can use any script name you like here, application is the default, where by convention, all of your other scripts are "rolled up". That's done by the file /app/javascripts/application.js, which culminates in the line
//= require tree .
which slurps up all the javascript files in the /app/assets/javascripts directory that are not already loaded by previous require directives in application.js, and concatenates them into the one published file.
A generic (rails new ...) generated site will have all of this done for you, so I recommend you try building a new stunt site from scratch and see what gets built for you. Try building a new app, then inside that, using the scaffold generator to make a couple or more models:
rails new test_blog
cd test_blog
rails g scaffold Post title body:text slug
rails g scaffold Author name email
rails g migration add_author_to_posts author:references
rake db:migrate
rails s
navigate to http://localhost:3000/posts
Everything you see will be run through the asset pipeline, although the full concatenation will not be there in development mode.
If you add some JS to the app/assets/javascripts/authors.js and posts.js, and refresh your browser, you should see those scripts appear in your browser's Developer tools when you inspect the DOM. In development, each file will be listed separately, as coming from /javascripts/posts- asdfsdfsdsdfsdafsdfsdafsd.js or similar (32 character hash, which is the MD5 of the file itself, is appended to the filename).
To see how this would work in production, you would first run:
rake db:create RAILS_ENV=production
rake db:migrate RAILS_ENV=production
rake assets:precompile RAILS_EN=production
and then when you started the dev server with the production version:
rails s production -p 3000
you would see all of the JS and CSS concatenated into application.js and application.css respectively. None of the individual files would appear at all. The whole thing will be minified and concatenated.
If you require some files in order in application.js, then only the files you don't require by name would be auto-loaded by the greedy require_tree operator. You might do this if you needed to specify that jQuery load before something else that needs it, for example. But otherwise, the files will be concatenated in alphabetical order and then minified and gzipped into one application-someMD5hashgoeshere.js file. The javascript_include_tag helper knows how to find that file and load it.
Walter
> To view this discussion on the web visit https://groups.google.com/d/
> On Jul 26, 2018, at 5:31 PM, David Merrick <merrickdav@gmail.com> wrote:
>
> Are you to give me an example of this please. javascript_include_tag helper
>
> On Fri, Jul 27, 2018 at 1:21 AM, Walter Lee Davis <waltd@wdstudio.com> wrote:
>
> > On Jul 26, 2018, at 1:43 AM, David Merrick <merrickdav@gmail.com> wrote:
> >
> > Got some issues not sure how to fix.
> >
> > My application.html.erb in Production on local system
> >
> > Has the following code. Comes up with the error '(index):39 Uncaught ReferenceError: play is not defined at onload ((index):39)"
> >
> > <!DOCTYPE html>
> > <html>
> > <head>
> > <title><%= full_title(yield(:title)) %></title>
> > <meta name="turbolinks-visit-control" content="reload">
> > <%= render 'layouts/rails_default' %>
>
> I am guessing that the partial in the line above this one is where the regular <%= javascript_include_tag :application %> would live?
>
> > <%= render 'layouts/shim' %>
> > </head>
> > <body onload="play()">
> > <%= render 'layouts/header' %>
> > <div class="container">
> > <% flash.each do |message_type, message| %>
> > <%= content_tag(:div, message, class: "alert alert-#{message_type}") %>
> > <% end %>
> > <%= yield %>
> > <%= render 'layouts/footer' %>
> > <%= debug(params) if Rails.env.development? %>
> > </div>
> > </body>
> > </html>
> >
> > Not sure how to fix that one?
> >
> > In Heroku I get this error 'GET https://morning-caverns-39088.herokuapp.com/assets/ 404 (Not Found)' which m,eans it can't find the assets/blackJack.js fileblackJack.js
> >
> > My BlackJack.html,erb file is as follows
> >
> > <script type="text/javascript" src="assets/blackJack.js" ></script>
>
> If you have put your scripts in the assets folder, then they have already been concatenated and minified into application.js. Loading a separate script here as a static html reference will fail in any normal Rails production environment. If you want to load it separately, you need to use the javascript_include_tag helper, which will also understand the fingerprint of the file (note that even in development, the URLs to individual resource files end with an MD5 hash of their contents, which is a cache-busting strategy. You don't need to know this directly, you would just use the helper and the correct link would be written out in the rendered HTML.
>
> I recommend you read the Rails Guide about the Asset Pipeline, it covers this and lots more.
>
> One thing I have noticed over the years is that when Rails makes something really difficult, it is often because doing things the easier way will lead you to a better design, or a better performing one. I have fought with the asset pipeline before, but I ended up writing better JS (namespaces, to avoid conflicts between modules) and then loading all of it at once, and letting Turbolinks handle the "go fast" part of the problem for me.
>
> Walter
>
> >
> > <div id = "blackJackgame">
> > <h2>Playing Black Jack</h2>
> > <div id = "blackJackcontrols">
> > <div class ="blackJackdealer"><button class = 'button' >Dealer</button></div>
> > <div class = "blackJackplayer"><button class = 'button' >Player</button></div>
> > </div>
> >
> > <div id = "blackJackcards">
> > <div id="blackJackdealersCards">
> > <span id = "BD0"></span>
> > <span id = "BD1"></span>
> > <span id = "BD2"></span>
> > <span id = "BD3"></span>
> > <span id = "BD4"></span>
> > <span id = "BD5"></span>
> > <span id = "BD6"></span>
> > <span id = "BD7"></span>
> > </div>
> >
> > <div id="blackJackplayersCards">
> > <span id = "BP0"></span>
> > <span id = "BP1"></span>
> > <span id = "BP2"></span>
> > <span id = "BP3"></span>
> > <span id = "BP4"></span>
> > <span id = "BP5"></span>
> > <span id = "BP6"></span>
> > <span id = "BP7"></span>
> > </div>
> > </div>
> > </div>
> >
> >
> > <div id = "blackJackbottomControls">
> > <div class ="blackJackplayButton"><button class = 'button' onclick="blackJackplayAgain()">Play Again</button></div>
> > <div id = "blackJackmoneyValue">Players Money is $5000</div>
> > <div id = "blackJackplayersReturn">Players Card Total is 0</div>
> > <div id = "blackJackmessagesValue">Messages</div>
> > <div class="blackJackbeat">
> > <form name ="subscribe" id="subscribe_frm" action="#">
> > <input class = 'button' type="button" id = "blackJackbeatenterBeat" name="submit" value="Enter Beat" onclick="blackJackgetBeat()" />
> > <input type="text" name="beat" id="blackJackbeatName" />
> > </form>
> > </div>
> > <div class = "hitNoHit">
> > <input class = 'button' type="button" id = "hit" name="submit" value="Hit" onclick="hit()" />
> > <input class = 'button' type="button" id = "nohit" name="submit" value="No Hit" onclick="noHit()" />
> > </div>
> > </div>
> > <script>
> > function play()
> > {
> > blackJackshowCardInitialCards();
> > playGame = true;
> > return dealerCount,playerCount,playGame
> > }
> > </script>
> >
> > My assets.rb file in config/initializers looks like this
> >
> > # Be sure to restart your server when you modify this file.
> >
> > # Version of your assets, change this if you want to expire all your assets.
> > Rails.application.config.assets.version = '1.0'
> >
> > # Add additional assets to the asset load path.
> > # Rails.application.config.assets.paths << Emoji.images_path
> > # Add Yarn node_modules folder to the asset load path.
> > Rails.application.config.assets.paths << Rails.root.join('node_modules' )
> >
> > # Precompile additional assets.
> > # application.js, application.css, and all non-JS/CSS in the app/assets
> > # folder are already added.
> > # Rails.application.config.assets.precompile += %w( admin.js admin.css )
> >
> > Rails.application.config.assets.precompile += %w( game.scss )
> > Rails.application.config.assets.precompile += %w( blackJack.js )
> > Rails.application.config.assets.precompile += %w( poker.js )
> > Rails.application.config.assets.precompile += %w( yaghtzee.js )
> > Rails.application.config.assets.precompile += %w( mastermind.js )
> >
> > My _rails_default.html.erb file in views/layouts looks like this
> >
> > <%= csrf_meta_tags %>
> > <%= stylesheet_link_tag 'application', media: 'all','data-turbolinks-track': 'reload' %>
> > <%= javascript_include_tag 'application', 'data-turbolinks-track': 'reload' %>
> >
> > If you can find why the function play() can't be seen and why the javascript files in Heroku can't be find that would be great.
> >
> > i put the links like <script type="text/javascript" src="assets/blackJack.js" ></script> for BlackJack.html,erb in BlackJack.html,erb because some function names were too similar causing issues.
> >
> > Cheers Dave
> >
> >
> > On Thu, Jul 26, 2018 at 4:42 PM, Eric Jesse Knutsen <dracorna@gmail.com> wrote:
> > Anything in browser javascript console? Is anything not being served properly? And, dumb question time but we all have these kind of moments, did you remember to precompile, and are all your JS libraries set to have pointers to the compiled locations of assets?
> >
> >
> >
> > Cheers,
> >
> >
> >
> > Jess
> >
> >
> >
> >
> >
> > From: David Merrick
> > Sent: Thursday, July 26, 2018 12:24 AM
> > To: Ruby on Rails: Talk
> > Subject: [Rails] Heroku and Javascript
> >
> >
> >
> > I have built a games website in Rails. Runs run on local system. But when deployed to Heroku the Javascript requests either run slow or freeze. Often the whole page freezes. I'm only using one Dyno as I'm still in the testing phase.
> >
> >
> >
> > Heroku doesn't have any suggestions to fix the problem
> >
> >
> >
> > Slug size on Heroku is 36.5. MiB of 500 MiB
> >
> >
> >
> > Cheers Dave
> >
> > --
> > You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
> > To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com .
> > To post to this group, send email to rubyonrails-talk@googlegroups.com .
> > To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/ .a26ccf22-ab23-4a07-a354- cd861ae9aa37%40googlegroups. com
> > For more options, visit https://groups.google.com/d/optout .
> >
> >
> >
> >
> > Virus-free. www.avast.com
> >
> > --
> > You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
> > To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com .
> > To post to this group, send email to rubyonrails-talk@googlegroups.com .
> > To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/ .5b595131.1c69fb81.a9594.1cec% 40mx.google.com
> >
> > For more options, visit https://groups.google.com/d/optout .
> >
> >
> >
> > --
> > Dave Merrick
> >
> > Daves Web Designs
> >
> > Website http://www.daveswebdesigns.co.nz
> >
> > Email merrickdav@gmail.com
> >
> > Ph 03 216 2053
> >
> > Cell 027 3089 169
> >
> > --
> > You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
> > To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com .
> > To post to this group, send email to rubyonrails-talk@googlegroups.com .
> > To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/CA%2B% .3DMcKaFV99bRhTyvS5XaYgUoNMA4aY GdgyR-WPebo8CxxnQJg%40mail. gmail.com
> > For more options, visit https://groups.google.com/d/optout .
>
> --
> You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com .
> To post to this group, send email to rubyonrails-talk@googlegroups.com .
> To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/ .960F3ED5-6812-4B27-8EAA- F3F6199E6C8B%40wdstudio.com
> For more options, visit https://groups.google.com/d/optout .
>
>
>
> --
> Dave Merrick
>
> Daves Web Designs
>
> Website http://www.daveswebdesigns.co.nz
>
> Email merrickdav@gmail.com
>
> Ph 03 216 2053
>
> Cell 027 3089 169
>
> --
> You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com .
> To post to this group, send email to rubyonrails-talk@googlegroups.com .
msgid/rubyonrails-talk/CA%2B% .3DMcKaykXB3ukFXYqwhyW% 3DgP59Bxh31Xf1RQa8K%3DJ% 2BwhQpD%3Dg%40mail.gmail.com
> For more options, visit https://groups.google.com/d/optout .
--
You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com .
To post to this group, send email to rubyonrails-talk@googlegroups.com .
To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/ .99647338-C3AF-45F2-8975- 2525A72DFB1D%40wdstudio.com
For more options, visit https://groups.google.com/d/optout .
Cell 027 3089 169
You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com.
To post to this group, send email to rubyonrails-talk@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/CA%2B%3DMcKZanC4ZS2CMY07KaHoM5o6miHrQq6SjhzyZ%3DExtE3m4iw%40mail.gmail.com.
For more options, visit https://groups.google.com/d/optout.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment