为网站添加多种语言

为网站添加多种语言

首先在项目文件夹下的config\initializers增加一个i18n.rb的文件、i18n是什么、就是英文单词国际化的意思、为了日常方便而简写成i18n、因为这单词一共有20个字母、包括i和n、

 

1 #encoding: utf-8
2 I18n.default_locale = :en
3
4 LANGUAGES = [
5 ['English', 'en'],
6 ["Español".html_safe, 'es'],
7 ["中文", 'cn']
8 ]

在里面写下如下的内容、第一行是必须的、保证ruby解释器以utf-8来解析文字、而且要放在第一行、切记切记、第二行就是指定网站的默认文字选择、狠显然、这里默认是显示英文、之后LANGUAGES下面的是可以自己随便填的、并不是系统的特定关键字、到时做成语言切换器时就会显示前面的、后面那两个字母是缩写、比如[‘English’, ‘en’]、前面是显示出来给别人看的、后面是为了写代码方便的简化符号、添加好需要加入的多国语言、然后保存、重启服务器、记得要重启、不然效果不会生效、

 

P.S.:对了第6行是西班牙语、直接用键盘打不出来、需要转义符号、其中的$ntilde;便是转义码、后面的.html_safe表示让浏览器使用转义器来显示出正常的西班牙文、

 

然后去config/routes.rb这里搞搞

 

 1 scope '(:locale)' do
2 resources :users
3 resources :orders
4 resources :line_items
5 resources :carts
6 resources :products do
7 get :who_bought, :on => :member
8 end
9 root :to => 'store#index', :as => 'store'
10 end

主要就是在迩需要切换国际化语言的页面上限定一个范围、这里从2到9行都是限定范围、使用scope ‘(:locale)’ do和end来确定这个范围

 

 

然后再去app/controllers/application_controller.rb这里搞搞

 

 1 before_filter :set_i18n_locale_from_params
2 # ...
3 protected
4 def set_i18n_locale_from_params
5 if params[:locale]
6 if I18n.available_locales.include?(params[:locale].to_sym)
7 I18n.locale = params[:locale]
8 else
9 flash.now[:notice] =
10 "#{params[:locale]} translation not available"
11 logger.error flash.now[:notice]
12 end
13 end

对了、还漏了一段

def default_url_options
{:locale => I18n.locale}
end

这些里面是干啥就不深究了、照抄就是了

 

然后就无非是在app/view的各种模版页html.erb和config\locales下面的语言配置文件里添加各种语言了、这里举一个例子

 1 <% if notice %>
2 <p id="notice"><%= notice %></p>
3 <% end %>
4
5 <h1>Your Pragmatic Catalog</h1>
6
7 <% @products.each do |product| %>
8 <div class="entry">
9 <%= image_tag(product.image_url) %>
10 <h3><%= product.title %></h3>
11 <%= sanitize product.description %>
12 <div class="price_line">
13 <span class="price"><%= number_to_currency(product.price) %></span>
14
15
16 <%= button_to “Add to Cart”, line_items_path(:product_id => product),:remote => true %>
17 </div>
18 </div>
19 <% end %>

把这里的第5行和第16行改成

<h1><%= t('.title_html') %></h1>

<%= button_to t('.add_html'), line_items_path(:product_id => product),:remote => true %>

然后再在config\locales添加迩需要的语言配置文件、比如按本文的约定是西班牙文es、英文是en、中文是cn、所以就需要在这里分别创建cn.yml、en.yml、es.yml

英文的en.yml

1 en:
2
3 store:
4 index:
5 title_html: "Your Pragmatic Catalog"
6 add_html: "Add to Cart"

注意这个yml格式文件非常的娇气、迩需要严格的保持层次间的缩进、下级的一定要在上级的后面、不然程序对不上号说找不到就麻烦了、真跟Python一个脾气出来的、这里就比较好明白了、en:表示一个语言类别、必须放在最前的层级、下面就是store和index、这也是对应着文件的目录的、因为莪们修改的这个文件就在app\views\store、这回明白了吧、然后title_html就对应着在模版页修改的<h1><%= t(‘.title_html’) %></h1>、t是限定语、不能随便改、title_html按理来说也是个随便迩自己起的变量名、但其实是有差别的!!比如迩写了西班牙文的配置文件

es.yml

1 es:
2
3
4
5 store:
6 index:
7 title_html: "Su Cat&aacute;logo de Pragmatic"
8 add_html: "A&ntilde;adir al Carrito"

这里的西班牙文由于需要用到转义字符来显示、键盘直接打不打出的、如果迩的变量名写成title或者add而不是title_html和add_html、它是解析不出实际的西班牙文的!而是照着把A&ntilde;adir al Carrito原文输出到网页中、切记啊!!

 

好了、现在关于怎么修改多语言环境也差不多了、讲一下最简单的切换方法、就是在网页中加入相应的后缀、比如网站是localhost:3000、那么想显示应该版便是localhost:3000/en、中文自然是跟cn、可总不能这样直接在地址栏里输来输去、不方便!所以莪们做个切换的菜单、

打开app\views\layouts的application.html.erb、添加以下的代码

1   <%= form_tag store_path, :class => 'locale' do %>
2 <%= select_tag 'set_locale',
3 options_for_select(LANGUAGES, I18n.locale.to_s),
4 :onchange => 'this.form.submit()' %>
5 <%= submit_tag 'submit' %>
6 <%= javascript_tag "$$('.locale input').each(Element.hide)" %>
7 <% end %>

放在相应的地方就行了、比较好看的是放在上面顶端、容易让人看到、就会产生了一个下拉的菜单栏、而菜单栏里的内容取决于迩在项目文件夹下的config\initializers的i18n.rb文件、LANGUAGES里的内容就是在这里控制的、至于为什么放在application.html.erb、这个地球人都知道了、因为这个是所有模版的母版页、也就是说在任何本站的页面都可以使用这个下拉切换菜单、但这步只是做个样子、还没实际的作用、还要在controller页添加相关的逻辑、

 

打开app/controllers/store_controller.rb文件、把里面的index方法修改一下

1   def index
2 if params[:set_locale]
3 redirect_to store_path(:locale => params[:set_locale])
4 else
5 @products = Product.all
6 @cart = current_cart
7 end
8 end

OK、大功告成、试下吧、觉得这位置不满意就去css样式表那里改

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/110527.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • python导入tensorflow方法_python导入包

    python导入tensorflow方法_python导入包若是你也遇到这个问题,说明你也没有理解tensorflow到底在哪里。当安装了anaconda3.6后,在PyCharm中设置interpreter,这个解释器决定了你在PyCharm环境中写的代码采用什么方式去执行。若是你的设置是anaconda下的python.exe。就会发现在PyCharm中写入importtensorflwoastf时,就会报错,提示没有tensorflow模块,…

  • 微信塔防小游戏开发教程,唤境引擎制作塔防游戏分享

    微信塔防小游戏开发教程,唤境引擎制作塔防游戏分享今天带来的是塔防游戏制作攻略!点击这里来下载工程文件,点击这里可以下载工程中所用的素材哦~预览状态时敌人会从四个生成点随机生成,并且会自动寻路绕过黑色墙体走向红色终点。点击黑色墙体可以创建炮塔,炮塔会自动攻击敌人。废话不多说,快打开唤境燥起来~!1.新建项目首先,打开唤境,点击欢迎页左上角的新建项目按钮。在弹出的项目设置中,选择窗口尺寸为800*600。命名为“塔防…

  • 树的高度和深度 | 结点的高度和深度「建议收藏」

    树的高度和深度 | 结点的高度和深度「建议收藏」有个缺点,看到什么东西不管是不是重点只要说不通总是爱钻牛角尖。对于树的高度和深度(以及结点的高度和深度)看了几本不同的书,都有各自的说法,多方查证吧,花了很多时间,最后归纳一个能说服我的说法吧。(´。•ᵕ•。`)♡树的高度和深度深度是从上往下定义的,从根结点开始数,高度是从下往上定义的,从叶子结点开始数。这个涉及到结点的层数,有的教材规定根结点在第0层,有的则规定根结点在第一层。…

  • jquery插件autoComplete自动弹出

    jquery插件autoComplete自动弹出

  • 盘点当下大热的 7 大 Github 机器学习『创新』项目

    盘点当下大热的 7 大 Github 机器学习『创新』项目本文将会分享近期发布的七大GitHub机器学习项目。这些项目广泛覆盖了机器学习的各个领域,包括自然语言处理(NLP)、计算机视觉、大数据等。最顶尖的Github机器学习项…

  • oracle认证考试培训_认证培训

    oracle认证考试培训_认证培训Ocp认证指的是Oracle库认证专家,属于Oracle中级认证,考取该项资格认证说明你已经具备了库中级技术水平。1、市场占有率和技术占有率高Oracle目前是全球大的企业软件公司,前100强企业当

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号