[問題] 管理 js assets

看板Ruby作者 (南洋大兜蟲)時間12年前 (2012/12/05 03:54), 編輯推噓0(000)
留言0則, 0人參與, 最新討論串1/1
網頁好讀版:http://ruby-china.org/topics/7315 ## Rails Guide Style 在 [Rails Guide 上面](http://goo.gl/Vysga)有這樣的寫法: <%= javascript_include_tag params[:controller] %> or <%= stylesheet_link_tag params[:controller] %> 但是這樣寫的話,在 production 時一定會報錯, 所以要在 `config.assets.precompile` 加上不少東西,類似: config.assets.precompile << Proc.new { |path| if path =~ /\.(css|js)\z/ full_path = Rails.application.assets.resolve(path).to_path app_assets_path = Rails.root.join('app', 'assets').to_path if full_path.starts_with? app_assets_path puts "including asset: " + full_path true else puts "excluding asset: " + full_path false end else false end } **然而這在 Rails Guide 上面並沒有提醒我們要做這件事情** (所以等等想貢獻一下提示到 docrails 這個 repo 上) ## Garber Irish Style 然而有另外一種方案: http://goo.gl/7bu5X 使用起來的話,以 `posts.js.coffee` 為例子: # posts.js.coffee SITENAME.posts = index: () -> # blablabla show: () -> # blablabla new: () -> # blablabla edit: () -> # blablabla update: () -> # blablabla 我覺得很有條理,而且比上述的 Rails Guide style 簡單很多, 如果要共用重複的代碼也可以這麼做: SITENAME.posts = index: () -> this.do_something() show: () -> this.do_something() new: () -> this.do_something() edit: () -> this.do_something() update: () -> this.do_something() do_something () -> #blablabla 因為管理方便,所以最近的專案都開始使用這個方法了。 --- 來此除了推廣 Garber Irish 的方法之外,也想向各位取經: 1. 不知道大家是怎麼管理自己的 javascript assets 的? 2. 大家會選擇上述哪一個方法? -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 140.113.5.35
文章代碼(AID): #1GlbJUeK (Ruby)
文章代碼(AID): #1GlbJUeK (Ruby)