ruby on rails开发B/S的相关经验

select_tag 当制定选项时用 options_for_select (数组,默认选定值)

 

界面元素除了 onclick 等事件属性一旦在界面上定义后就不能在 javascript 中修改,而其他 html 属性则可修改

 

Select 的默认值设置为 在想要设置为默认值的 option 中加入 selected=true

 

当页面减少数据后可根据控制器中原来的数量减去页面传回来的数据来得到较少的数据

 

javascript 中引用控制器传来的数据时 应用引号把 <%= %> 包起来才能用

 

javascript 中使用 for 循环

for(var i=0;i<document.all.radiobutton.length;i++){
if(document.all.radiobutton[i].status){
recieve = document.all.radiobutton[i].value;
break;
}
}

 

javascript 同时也可以嵌套在 ruby 中的 for ..in … 循环中

 

在下层浮动的块级元素定义宽度,在他上面建立非浮动的块级元素则可以使用 margin:0 auto;

注意可以使用 margin:0 auto; 样式的块级元素一定不能让他浮动起来,否则无效

 

若块级元素浮动起来后宽度不够则后面的块级元素将排列在上一个的下面而不是上一个的后面

 

request.post? 判断在控制器中该控制器是否为 postform_for 默认情况是 post ,所以经常用来判断是否有 form_for 返回到控制器

 

在循环中指定跳转 redirect_to 时需要在前面加入 return ,否则 server 就崩溃了

 

初始化数组 xxx=[] 初始化哈希 xxx={}

 

数组中可以 << 任意类型的值

 

时间类型可以直接进行进行对比

 

Javascipt 通过 window.location…(url) 将跳转到制定的网址

 

Rubyrandor 不经过 application ,而 redirect_to 叫经过

 

%w() 括号内放入加空格的值则将形成字符串数组

 

eEdit 中选择 view 中的 word wrap 选择 none 则是不自动换行

eCtrl+f 选择他里面选项的第一项则是将字符转移如 \n 等换行

form 表单中的 enctype="multipart/form-data" 的属性:将数据分段上传(作用于比较大的数据),并且以二进制方式上传,没有指明的则以 ACICAL 码上传

 

rails 环境中 RAILS_ROOT 指定的是当前路径

 

redirect_torender 的区别在于 redirect_to 走控制器;而 render 直接渲染 action 对应的界面,这里应当为 render 渲染的界面准备好数据,因为 render 不走控制器

 

action 中的 render

render (:text => "hello world!")

将响应字符串

render (:inline => string, [:type => "rhtml"|"rxml"])

把传入的 string 渲染成模板( rhtml 或者 rxml

render (:action => action_name)

直接调用某个 action 的模板,相当于 forward 到一个 view

render (:file=>’/sss/sss.erb’, [:use_full_path => true|false])

使用某个模板文件 render, use_full_path 参数为 true 时可以传入相对路径

render(:template => name)

使用模板名 render ,例如 : render(:template => "blog/short_list")

render(:partial => name)

以局部模板渲染

render :json=>{ 其中输入 hash}

将响应以 json 形式响应客户端 , 响应的格式为 json 的字符串形式,所以要转化为 json 对象, eval(‘(’+ 接受响应的变量 +’)’) 将得到实际的 json 对象

render :xml => {:name => "David"}.to_xml

将转换成 xml 的形式

render(:nothing=>true)

什么也不输出 , 包括 layout

render()

默认的的 render, 相当于 render(:action => self)

 

inputname 值可以为 xxx[] 的形式,这样控制器将收到 params[xxx] 的数组

 

若把某一元素放到表格 td 的外部将导致此元素位置不为开发时位置一样,大多数情况下浏览器会把他解析到 table 的外部

 

 

Json 的格式:

x=[{" 城市 ":" 北京 "," 面积 ":16800," 人口 ":1600},{" 城市 ":" 上海 "," 面积 ":6400," 人口 ":1800}]

1 并列的数据之间用逗号( )分隔。

2 映射用冒号( )表示。

3 并列数据的集合(数组)用方括号 ("[]") 表示

4 映射的集合(对象)用大括号( “{}” )表示。

5 数组元素的引用格式 x[0]

5 对象属性的引用格式 x[0][“ 城市 ”]

例如:这个数组中包含 2 个对象,每个对象分别有城市,面积,人口属性

注意:数组表示有序的集合,对象表示无序的集合

 

select("post", "person_id", Person.find(:all).collect {|p| [ p.name, p.id ] }, { :include_blank => true }){ :include_blank => true }


可以设置select


元素的默认值为空的option


 

javascript 中的变量插入界面中时可以拼字符串的方式,如 $ajavascript 中的变量那么, $('<td>'+$a+'</td>') ,这样 td 元素中就插入了 javascript 中的变量了,在把 td 插入到界面就 OK

 

扩展快

多台的反向关联

sumit 的时候可以用 jquery 中的 submit 函数先进行其他操作,其他操作完成后在使表单 submit

 

分页功能在课程总库里有

 

对模型增加事务,对模型的操作事务则 roll back

模型名 .transaction do

对模型进行的操作

End

 

Ruby 中整数除以整数仍然是整数。

 

递归算法 : 函数自己调用自己

 

Javascript 中用 var 声明一个变量是局部变量,不用则是一个全局变量,局部变量跳出函数后不起作用。

 

界面应用框架 iframe 首先定义 iframename 属性,通过建立 a 标签并设置 a 标签中的 target='iframename 的名称 ' 从而实现单击 a 改变 iframe 框架

 

window.top // 最顶层窗口
window.self //
当前窗口
window.parent //
父级窗口

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值