Ruby裡面有4種比較方法,equal?, eql?, ==, ===,而且在不同的類裡面表現的很不一樣。在使用的時候也特別容易搞糊塗。 這篇博文將示範一些代碼來講解各個方法。== - 類意義上的 相等,需要每個類自己定義實現在特定類中覺得兩個對象是否相同,需要看業務上的邏輯表象,所有由程式員覆蓋該方法的定義,決定兩個對象是否相同。比如 String 類,他是來計較實際的文字串是否相同,而不在意是否來自同一個記憶體地區。>> a = "abc"#=> "abc"
前兩天在寫代碼的時候,突然收到警告說項目代碼中存在 XSS 漏洞,遂立即根據報告的 URL 排查頁面代碼,雖然很快就修複了,而且同樣問題的討論兩年前就有了,一般來說相對有經驗的同學也應該都知道這個點,但是還是覺得有必要寫出來,再次提醒一下其他小夥伴,避免踩坑。問題根源其中,在找到的漏洞出現的地方,都存在類似以下這樣的 slim 代碼:input class='xxx' value==params[:account]問題就出在雙等號 == 上,因為在 slim 跟 ERB 模板(其他模板比如
下面這段程式讓我糾結了很久,Ruby中private的概念真的很奇怪。。。class Test private def test_print puts 'test' endendclass Test2 < Test def test_print2 # self.test_print #=> 這裡加上self就不能調用,private method `test_print' called for # (NoMethodError) test_print #=>
前言隨著RubyGnome2庫越來越完善,以及ruby1.9的效能提升,用Ruby編寫GUI程式漸漸從我的業餘愛好轉為我工作的一個重要部分。 用Ruby寫程式確實很有樂趣,它可以讓你的想法快速地以一種優雅的方式實現。本文介紹的一個gem就是一個例子,用很少的代碼,實現很有趣的功能,讓編寫Ruby
中文亂碼解決辦法cmd下中文不能輸入將cmd字碼頁改成936:chcp 936ruby 讀取中文強制設定為utf-8可以在檔案中加一個備註陳述式 # encoding: UTF-8,ruby就會用utf-8格式載入cmd輸出亂碼這個解決不掉, 我看到有人用了一個第三方庫來解決輸出 require 'iconv' cov = Iconv.new( 'gbk', 'utf-8') puts cov.iconv("北京奧運會!")PS:
使用builder建立XMLbuilder安裝方法:gem install builderrequire 'builder' x = Builder::XmlMarkup.new(:target => $stdout, :indent => 1) #":target =>$stdout"參數:指示輸出內容將被寫向標準輸出控制台 #":indent =>1"參數:XML輸出形式將被縮排一個空白字元x.instruct! :xml,:version
1.導致你的 Rails 應用變慢無非以下兩個原因: 在不應該將 Ruby and Rails 作為首選的地方使用 Ruby and Rails。(用 Ruby and Rails 做了不擅長做的工作) 過度的消耗記憶體導致需要利用大量的時間進行記憶體回收。Rails 是個令人愉快的架構,而且 Ruby 也是一個簡潔而優雅的語言。但是如果它被濫用,那會相當的影響效能。有很多工作並不適合用 Ruby and Rails,你最好使用其它的工具,比如,資料庫在大資料處理上優勢明顯,R
jquery_ujs 對 rails 來說,是一個非常重要的組件,它包含在 rails 的預設組件之中。jquery ujs 包含一些非常便捷的功能,比如確認對話方塊、觸發 ajax、自動禁用表單提交按鈕等,本文主要討論的是觸發 ajax 的功能。通過添加簡單的標籤屬性,jquery ujs 可以把一個普通的連結或者表單轉換成 ajax 提交,而不需要寫 JavaScript 代碼。<%= link_to '關閉項目', close_project_path(project),
數實值型別(Number)整型(Integer)整型分兩種,如果在31位以內(四位元組),那為Fixnum執行個體。如果超過,即為Bignum執行個體。整數範圍從 -230 到 230-1 或 -262 到 262-1。在這個範圍內的整數是類 Fixnum 的對象,在這個範圍外的整數儲存在類 Bignum 的對象中。您可以在整數前使用一個可選的前置字元號,一個可選的基礎指標(0 對應 octal,0x 對應 hex,0b 對應
讓我們編寫一個簡單的 Ruby 程式。所有的 Ruby 副檔名都是 .rb。所以,把下面的原始碼放在 test.rb 檔案中。執行個體#!/usr/bin/ruby -wputs "Hello, Ruby!";在這裡,假設您的 /usr/bin 目錄下已經有可用的 Ruby 解譯器。現在,嘗試運行這個程式,如下所示:$ ruby test.rb這將會產生下面的結果:Hello, Ruby!您已經看到了一個簡單的 Ruby 程式,現在讓我們看看一些 Ruby 文法相關的基本概念:Ruby
Ruby 注釋注釋會對 Ruby 解譯器隱藏一行,或者一行的一部分,或者若干行。您可以在行首使用字元( # ):# 我是注釋,請忽略我。或者,注釋可以跟著語句或運算式的同一行的後面:name = "Madisetti" # 這也是注釋您可以注釋多行,如下所示:# 這是注釋。# 這也是注釋。# 這也是注釋。# 這還是注釋。下面是另一種形式。這種塊注釋會對解譯器隱藏 =begin/=end 之間的行:=begin這是注釋。這也是注釋。這也是注釋。這還是注釋。=endRuby 中文編碼用 Ruby
Ruby 環境變數Ruby 解譯器使用下列環境變數來控制它的行為。ENV 對象包含了所有當前設定的環境變數列表。對於 Unix,使用 env 命令來查看所有環境變數的列表。HOSTNAME=ip-72-167-112-17.ip.secureserver.netRUBYPATH=/usr/binSHELL=/bin/bashTERM=xtermHISTSIZE=1000SSH_CLIENT=122.169.131.179 1742
Ruby 安裝 - Linux下面列出了在 Linux 機器上安裝 Ruby 的步驟。注意:在安裝之前,請確保您有 root 許可權。源碼安裝下載最新版的 Ruby 壓縮檔。請點擊這裡下載。下載 Ruby 之後,解壓到新建立的目錄下:$ tar -xvzf ruby-2.2.3.tgz $ cd ruby-2.2.3現在,配置並編譯原始碼,如下所示:$ ./configure$ make$ sudo make install安裝後,通過在命令列中輸入以下命令來確保一切工作正常:$ruby
用 @wip (工作進行中)標籤標記你未完成的情境。這些情境不納入考慮,且不標記為測試失敗。當完成一個未完成情境且功能測試通過時,為了把此情境加至測試套件裡,應該移除 @wip 標籤。 配置你的預設設定檔,排除掉標記為 @javascript 的情境。它們使用瀏覽器來測試,推薦停用它們來增加一般情境的執行速度。 替標記著 @javascript
把 mails 命名為 SomethingMailer。 沒有 Mailer 字根的話,不能立即顯現哪個是一個 Mailer,以及哪個視圖與它有關。 提供 HTML 與純文字視圖模版。 在你的開發環境啟用信件失敗發送錯誤。這些錯誤預設是被停用的。 # config/environments/development.rb
視圖、模型與控制器裡不應使用語言相關設定與字串。這些文字應搬到在 config/locales 下的語言檔案裡。當 ActiveRecord 模型的標籤需要被翻譯時,使用activerecord 範圍:en: activerecord: models: user: Member attributes: user: name: "Full name"然後 User.model_name.human 會返回 "Member" ,而
不要直接從視圖調用模型層。 不要在視圖構造複雜的格式,把它們輸出到視圖 helper 的一個方法或是模型。 使用 partial 模版與布局來減少重複的代碼。 加入 client side validation 至慣用的 validators。 要做的步驟有:
把 schema.rb 儲存在版本管控之下。 使用 rake db:scheme:load 取代 rake db:migrate 來初始化空的資料庫。 使用 rake db:test:prepare 來更新測試資料庫的 schema。 避免在表裡設定預設資料。使用模型層來取代。 def amount self[:amount] or 0
當 HTTP 響應是一個與存在的格式不同的格式時(XML 和 JSON),需要某些額外的格式解析,創一個你慣用的格式,並在類別中使用它。慣用的格式應當實作下列方法:extension, mime_type, encode 以及 decode。 module ActiveResource module Formats module Extend module CSVFormat
避免改動預設的 ActiveRecord(表的名字、主鍵,等等),除非你有一個非常好的理由(像是不受你控制的資料庫)。 把宏風格的方法放在類別定義的前面(has_many, validates, 等等)。 偏好 has_many :through 勝於 has_and_belongs_to_many。 使用 has_many :through 允許在 join