Sinatra 头部代码实践,helpers 的使用。

xds2000 · 2012年05月25日 · 最后由 tency 回复于 2012年06月01日 · 3206 次阅读

sinatra 的简洁是大家有目共睹的,我今天介绍的文章是说的使用 helpers 简化 sinatra 头部,重点在于别人构建代码的思路,具体代码还需要你多练习才能灵活运用。

http://rubysource.com/using-sinatra-helpers-to-clean-up-your-code/

@xds2000 用 Sinatra.搭建个人 blog 这个挺好的 :D

这个思路不错,在代码里通过定义引入 js 等文件,比在 view 里通过 partial 等方式灵活很多。

最终代码的处理非常干净漂亮,不过我认为这个处理手法跟 Rails 的 javascripts_include_tag 的处理手法如出一辙。

https://raw.github.com/daz4126/sinatra-head-cleaner/master/sinatra/head_cleaner.rb

require 'sinatra/base'

module Sinatra
  module ClearHead
    def meta
      html="<meta charset=\"utf-8\" /><meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, minimum-scale=1.0\"/>"
      html << "<meta name=\"description\"content=\"#{settings.desc}\"  />" if settings.desc
      html << "<meta name=\"author\" content=\"#{settings.author}\" />" if settings.author
    end

    def favicon
      "<link href=\"/favicon.ico\" rel=\"shortcut icon\" />"
    end

    def ie_shim
      "<!--[if lt IE 9]><script src=\"http://html5shiv.googlecode.com/svn/trunk/html5.js\"></script><![endif]-->"
    end

    def title value=nil
      @title = value || settings.title || "untitled"
    end

    def title_tag
      "<title>#{@title}</title>"
    end

    def path_to script
      case script
        when :jquery then 'https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js'
        when :rightjs then 'http://cdn.rightjs.org/right-2.3.0.js'
        when :backbone then 'http://cdnjs.cloudflare.com/ajax/libs/backbone.js/0.9.0/backbone-min.js'
        when :underscore then 'http://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.3.1/underscore-min.js'
        #moo, prototype, scriptaculous, jquery ui, yui, dojo, raphael, extjs      
        else "/javascripts/#{script}.js"
      end
    end

    def javascripts(*args)
      js = []
      js << settings.javascripts if settings.respond_to?('javascripts')
      js << args
      js << @js if @js
      js.flatten.uniq.map do |script| 
        "<script src=\"#{path_to script}\"></script>"
      end.join
    end

    def js(*args)
      @js ||= []
      @js = args
    end

    def styles(*args)
        css = []
        css << settings.css if settings.respond_to?('css')
        css << args
        css << @css if @css
        css.flatten.uniq.map do |stylesheet| 
          "<link href=\"/#{stylesheet}.css\" media=\"screen, projection\" rel=\"stylesheet\" />"
        end.join    
    end

    def css(*args)
      @css ||= []
      @css += args
    end

    def webfonts(*args)
      "<link href=\"http://fonts.googleapis.com/css?family=#{((@fonts?settings.fonts+@fonts:settings.fonts)+args).uniq.*'|'}\" rel=\"stylesheet\" />"
    end
  end

  helpers ClearHead
end

思路肯定是相通的,用 padriono 就自带一个实现

需要 登录 后方可回复, 如果你还没有账号请 注册新账号