- 浏览: 242234 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (173)
- ruby (38)
- rails (42)
- javascript (7)
- jquery (1)
- linux (15)
- design patterns (1)
- project management (6)
- IT (7)
- life (19)
- data structures and algorithm analysis (2)
- css (1)
- prototype (1)
- mysql (4)
- html (1)
- git (3)
- novels (1)
- c (1)
- Latex (13)
- erlang (1)
- 求职 (1)
- API (0)
- Shell (4)
- Rabbit MQ (1)
- 计算机基础 (1)
- svn (2)
- 疑问 (1)
最新评论
-
zhangyou1010:
回去倒立去,哈哈。
作为一个程序员,身体很重要! -
Hooopo:
Ruby MetaProgramming is all abo ...
Metaprogramming Ruby -
orcl_zhang:
yiqi1943 写道LZ现在上学还是工作呢工作好多年了。不过 ...
2011年 -
yiqi1943:
LZ现在上学还是工作呢
2011年 -
tjcjc:
query cache
就是一个简单的hash
key就是sq ...
Rails sql延迟加载和自带缓存
客户的要求(查看图片),点击Range,可以选择一个日期范围,点击Calc可以选择日期的计算,计算完后,结果会同时显示在后面的input里,可以看下图片。因为考虑到很多地方要用到,所以写到help方法里了。感觉这个东西以后还会用,估计其他的同学也有可能会用到类似的功能,所以发出来,大家看看。计算日期用ruby代码来写很方便,用js代码来写,就很麻烦。
_time_period.html.erb
关于这段js代码,其实一直在后台有ruby实现的,相对而言,简单很多
但是考虑到,如果用js的话,可以避免多余的和后台通信,而且以后复用的话,不用在加很多代码。
关于这段js日期计算,冥冥之中感觉应该还有比较更好的写法,对js日期这块不熟悉,希望有经验的能提出意见。
就是他了,year,month,day在这里其实每次只有一个值在变,但是变化的范围不确定。
恩,没注意到 。。。我改下。。。
顺便把页面html里的几个相同的js代码也拿出来放一起。
因为有部分代码是旧有的,所以代码风格看上去有点窘。
方法语法?你指的是help?请明示。谢谢
_time_period.html.erb
<% prefix << '_' unless prefix.blank? %> <a onclick="$('<%= prefix %>unequal').style.display=($('<%= prefix %>unequal').style.display=='none' ? '' : 'none');$('<%= prefix %>widget').style.display='none';$('<%= prefix %>change_type').value = '';$('<%= prefix %>_num').value='';$('<%= prefix %>time_type').value='';$('#<%= prefix %>big').value = '';$('<%= prefix %>less').value='';" >Range</a> <a onclick="$('<%= prefix %>widget').style.display=($('<%= prefix %>widget').style.display=='none' ? '' : 'none');$('<%= prefix %>unequal').style.display='none';$('<%= prefix %>big').value = '';$('<%= prefix %>less').value='';$('<%= prefix %>change_type').value = '';$('<%= prefix %>time_num').value='';$('<%= prefix %>time_type').value='';" >Calc</a><span> = <%= calendar_date_select_tag("#{prefix}equal",nil,:style => "width: 80px;",:embedded => false,:year_range => 30.years.ago..-30.years.ago) %> </span><span id='<%= prefix %>unequal' style='display: none;'>> <%= calendar_date_select_tag("#{prefix}big",nil,:style => "width: 80px;",:embedded => false,:year_range => 30.years.ago..-30.years.ago) %> < <%= calendar_date_select_tag("#{prefix}less",nil,:style => "width: 80px;",:embedded => false,:year_range => 30.years.ago..-30.years.ago ) %> </span> <span id='<%= prefix %>widget' style='display:none;'> <script type="text/javascript"> var equal = $('<%= prefix %>equal'); var change_type = $('<%= prefix %>change_type'); var time_num = $('<%= prefix %>time_num'); var time_type = $('<%= prefix %>time_type'); equal.observe('change', function(event){ count_date(); }); change_type.observe('change', function(event){ count_date(); enter_equal(); }); time_num.observe('change', function(event){ count_date(); enter_equal(); }); time_type.observe('change', function(event){ count_date(); enter_equal(); }); function enter_equal(){ if($F('<%= prefix %>equal')==''){alert('Please enter a date first!');} } function count_date(){ if((!equal.value.blank()) && (!change_type.value.blank()) && (!time_num.value.blank()) && (!time_type.value.blank())){ var time_num_number = Number(time_num.value); if (/^\d+$/.test(String(time_num.value)) && IsDate(equal.value)) { var r = equal.value.match(/^(\d{1,4})([-|\/])(\d{1,2})\2(\d{1,2})$/); var year = Number(r[1]); var month = Number(r[3]); var day = Number(r[4]); if(time_type.value == 0){ $('<%= prefix %>result').value = equal.value; } else { if(change_type.value == 'plus' && time_type.value == 'days'){ day = day + time_num_number; } else if (change_type.value == 'plus' && time_type.value == 'months') { month = month + time_num_number; } else if (change_type.value == 'plus' && time_type.value == 'years'){ year = year + time_num_number; } else if (change_type.value == 'minus' && time_type.value == 'days'){ day = day - time_num_number; } else if (change_type.value == 'minus' && time_type.value == 'months'){ month = month - time_num_number; } else if (change_type.value == 'minus' && time_type.value == 'years'){ year = year - time_num_number; } var result = correct_date(Number(year),Number(month),Number(day)); $('<%= prefix %>result').value = result; } } else { $('<%= prefix %>result').value = ''; } } else { $('<%= prefix %>result').value = ''; } } </script> <select id='<%= prefix %>change_type' style='width: 80px;'> <option value=''>(+/-)</option> <option value='plus'>+</option> <option value='minus'>-</option> </select> <%= text_field_tag("#{prefix}time_num",nil,:style => 'width: 80px;' ) %> <select id='<%= prefix %>time_type' style='width: 80px;' > <option value=''>(d/m/y)</option> <option value='days'>Days</option> <option value='months'>Months</option> <option value='years'>Years</option> </select> <input type='text' readonly='readonly' id='<%= prefix %>result' value='' size=10 /> </span>
<%= render :partial => 'time_period',:locals => { :prefix => ''} %>
//匹配//yyyy-mm-dd || yyyy/mm/dd function IsDate(str) { var r = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/); if(r==null)return false; var d = new Date(r[1], r[3]-1, r[4]); return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]); } //修正日期 //这里一直想不到很好的实现方法 function correct_date(year,month,day){ var stand_day = day_max(year,month); if(day > stand_day){ day = day - stand_day; month = month + 1; } if(month > 12){ month = month - 12; year = year + 1; } if(day <= 0){ var last_stand_day = day_max(year, month - 1); month = month - 1; day = day + last_stand_day; } if(month <= 0){ month = month + 12; year = year - 1; } if(year <= 0){ alert('invalid year!'); return false; } var str_month = (month >= 10) ? String(month) : '0'+ String(month); var str_day = (day >= 10) ? String(day) : '0'+ String(day); var str = String(year)+'-'+str_month+'-'+str_day; if(IsDate(str)){ return str; } else { return correct_date(year,month,day); } } //当月的最大日期 function day_max(year,month){ if(month==4 || month==6 || month==9 || month==11){ return 30; } else if(month==1 || month==3 || month==5 || month==7 || month==8 || month==10 || month==12){ return 31; } else { if(isleap(year)){ return 29; } else { return 28; } } } //是否是闰年 function isleap(year){ return (year % 4 == 0 || (year % 100 == 0 && year % 400 == 0)) }
关于这段js代码,其实一直在后台有ruby实现的,相对而言,简单很多
if params[:change_type] == "plus" date = params[:equal].to_date + params[:time_num].to_i elsif params[:change_type] == "minus" date = params[:equal].to_date - params[:time_num].to_i end if params[:change_type] == "plus" date = date.months_since(params[:time_num].to_i) elsif params[:change_type] == "minus" date = date.months_ago(params[:time_num].to_i) end
但是考虑到,如果用js的话,可以避免多余的和后台通信,而且以后复用的话,不用在加很多代码。
关于这段js日期计算,冥冥之中感觉应该还有比较更好的写法,对js日期这块不熟悉,希望有经验的能提出意见。
就是他了,year,month,day在这里其实每次只有一个值在变,但是变化的范围不确定。
//修正日期 function correct_date(year,month,day){ var stand_day = day_max(year,month); if(day > stand_day){ day = day - stand_day; month = month + 1; } if(month > 12){ month = month - 12; year = year + 1; } if(day <= 0){ var last_stand_day = day_max(year, month - 1); month = month - 1; day = day + last_stand_day; } if(month <= 0){ month = month + 12; year = year - 1; } if(year <= 0){ alert('invalid year!'); return false; } var str_month = (month >= 10) ? String(month) : '0'+ String(month); var str_day = (day >= 10) ? String(day) : '0'+ String(day); var str = String(year)+'-'+str_month+'-'+str_day; if(IsDate(str)){ return str; } else { return correct_date(year,month,day); } }
评论
5 楼
orcl_zhang
2010-07-31
发现je一个bug,我代码贴上去是
yearyear = year - time_num_number;
但是我实际上代码是
year = year - time_num_number;
不信你贴下来看看。。
yearyear = year - time_num_number;
但是我实际上代码是
year = year - time_num_number;
不信你贴下来看看。。
4 楼
orcl_zhang
2010-07-31
鹤惊昆仑 写道
为啥不用模板哪?直接拼字符串可真难维护。
恩,没注意到 。。。我改下。。。
顺便把页面html里的几个相同的js代码也拿出来放一起。
因为有部分代码是旧有的,所以代码风格看上去有点窘。
3 楼
鹤惊昆仑
2010-07-31
为啥不用模板哪?直接拼字符串可真难维护。
2 楼
orcl_zhang
2010-07-30
Soloara 写道
LZ的方法语法不够优美
方法语法?你指的是help?请明示。谢谢
1 楼
Soloara
2010-07-30
LZ的方法语法不够优美
发表评论
-
calendar
2012-02-24 11:04 863http://fullcalendar.vinsol.com/ ... -
ActiveRecord::Dirty
2011-11-21 10:29 785引用Track unsaved attribute chang ... -
TinyTDS
2011-09-20 09:29 852tiny_tds https://github.com/ra ... -
pandoc-ruby
2011-09-11 11:50 1196https://github.com/alphabetum/p ... -
Rails: Calling render() outside your Controllers
2011-04-28 17:15 831From:http://blog.choonkeat.com/ ... -
为什么这样才能装上
2011-02-20 10:39 1041引用u2@u2-laptop:~$ sudo gem inst ... -
Rails的transaction
2011-01-07 18:36 3055今天同事问我关于rails transaction,如 ... -
Rails sql延迟加载和自带缓存
2010-12-30 01:11 1610color_lot_manuallies = color_lo ... -
关于rhtml
2010-12-23 00:26 866在视图里有这样一段代码 sorted_op_items = o ... -
will_paginate ajax
2010-11-26 13:21 909两种方法 一, @@pagination_options ... -
save > save!(转)
2010-11-19 19:57 750Thoughtbot folks have a great a ... -
USE INDEX with Active Record finders(转)
2010-11-18 22:07 888可以通过强制指定index的方法优化find MySQL do ... -
html转义
2010-11-17 23:03 953$("#contacts").html(& ... -
Rails HTTP Status Code to Symbol Mapping
2010-11-17 22:40 1621http状态码http://zh.wikipedia.org/ ... -
Scaling Rails很不错的视频
2010-09-29 18:10 821自从railscasts开始讲解rails3后就很久没看了。 ... -
ActionController源码(待续)
2010-09-20 15:14 1020/usr/local/lib/ruby/gems/1.8/ge ... -
rails源码ActionSupport(待续)
2010-08-31 16:59 929一些奇淫技巧 class Object # An ... -
动态的增加auto_complete
2010-08-30 12:17 892http://www.iteye.com/problems/3 ... -
rails 记录
2010-08-26 15:27 737代码里有这样一句 self.purchase_invoices ... -
用Array来实现OrderedHash
2010-08-18 14:29 912偶然发现电脑的角落里有这样的一段代码.功能是用Array实现的 ...
相关推荐
这个文档题目是“东财《计算机应用基础》20春单元作业三答案”,描述中没有额外信息,主要标签为“作业”。根据提供的部分内容,我们可以总结出以下几个计算机应用基础的知识点: 1. **密码技术**:主要用于实现...
Excel是一款强大的电子表格软件,支持数据录入、格式设置、公式计算和图表制作。使用公式和数据透视表可以进行复杂的数据分析。通过超级链接功能,可以方便地访问网络上的文件。单元格中的内容可以是文本、日期、...
安卓上用于加载的Webview视图窗口只是作为类浏览器而存在,在安卓上更是只能同时运行一个Webview。(2)跨域数据交互问题。不同的Webview之间无法共享数据。(3)页面自适应问题。页面难以兼容适应不同分辨率的设备...
- **知识点详解**:Web 上的每个资源都有一个唯一的 URL (Uniform Resource Locator) 来标识该资源的位置及访问方式。URL 是一种标准的命名机制,用于描述资源的位置及如何对其进行访问。因此,正确答案为 A。 ### ...
7. **turtle库**:turtle是Python中的一个图形绘制库,`home()`函数确实将画笔定位到原点并朝向东,`circle()`用于画圆,而`seth(x)`设置画笔方向,不是向前移动。 8. **二维数组**:在C语言中,数组`a[3][4]={{3,4...
另一题要求学生描述如何在Windows操作系统中复制D盘指定文件夹中的特定类型的文件到E盘另一个文件夹,这涉及文件管理的基本操作。此外,还讨论了PowerPoint中的超级链接功能,通常用于创建页面间的跳转,可在“动作...
- **知识点**: Telnet 协议允许用户远程登录到另一台计算机上执行操作。 - **解释**: Telnet 是一种基于 TCP/IP 协议的应用程序,允许用户通过网络远程访问并控制其他计算机系统。 ### 15. 未知问题 - **知识点**: ...
QTP 中根据日期计算年龄的方法 - **算法**: 介绍一种简单有效的方法来计算日期对应的年龄。 - **示例**: 包含具体的 VBS 脚本代码实现。 #### 19. 测试报告的重要性 - **意义**: 讨论为什么创建详细的测试报告对于...
这种布局管理器将容器分为五个区域:北、南、东、西和中心。 #### 8. 关系运算的时间复杂度 在关系运算中,**笛卡儿积**通常是耗时最长的操作之一。笛卡儿积涉及到两个集合的所有元素的配对,因此其时间复杂度较高...
- **解释**: 页面页眉通常用于显示每一页的标题、日期、页码等基本信息,以便读者快速识别当前页的信息并了解上下文。 ### 3. Access中的事件 - **知识点**: Access支持多种类型的事件,如**键盘事件**、**鼠标...
16. 四个选项中,DTOC(DATE()), DATE(), YEAR(DATE())都返回日期类型;ALLTRIM()返回字符串,ASC()返回字符编码,SPACE()返回空格字符串;EOF(), RECCOUNT(), DBC()分别返回布尔值、整数和数据库连接;STR(), DTOC()...
- **页眉和页脚**:在“页眉/页脚”选项卡中,可以添加定制的文本、日期、页码等内容,以便于识别和组织打印出的页面。 - **工作表选项**:在“工作表”选项卡,可以设置是否打印网格线、工作表标签、行号和列标等。...
**一个页面调用了多个验证控件,当有其中的一个验证未通过时,整个页面不会被通过验证**: 正确。 - D. **一个服务器控件可同时被多个验证控件验证**: 正确。 - **正确答案**: A. 在客户端和服务器端都能进行验证...
1. **BorderLayout**:将容器划分为五个区域:东、南、西、北、中,适用于需要固定布局的应用场景。 ### 菜单文件的执行 1. **生成并执行菜单程序文件**:要运行菜单文件,首先需要将其编译为菜单程序文件(`.MPR` ...
- **答案解析**:在Model1中,控制器通过`<jsp:forward>`标签分派请求给另一个JSP页面。 ### 13. 滚动条事件 - **Scroll事件**:当用户滚动滚动条时触发。 - **答案解析**:Scroll事件用于响应滚动操作。 ### 14....
当屏幕上有多个应用程序时,此快捷键可以帮助用户快速返回桌面查看未被遮挡的信息。 - **Windows+L**:快速锁定电脑。这对于离开座位时保护个人信息安全非常重要。 - **F1**:帮助键。通常用于打开软件的帮助文档。 ...
用户在此页面可以根据日期查看最近一段时间的比赛赛程和对阵双方的球队。管理员在后台对赛程进行管理 (7)赛事数据统计管理 用户在这个页面可以查看每天各项数据排名前5名的球员以及他们所打出的数据。管理员在...
- 如果插入的记录中包含了非空值,则`AUTO_INCREMENT`列将从该值之后开始计算下一个自增值。 #### 5. 实现递归调用中的存储分配 - **知识点**: 实现递归调用时的数据结构选择。 - **详细解释**: - 在实现递归调用...
4. 历史上的今天:查询特定日期的历史事件,需要有历史数据的数据库支持。 5. 星座运势:根据用户输入的星座提供运势预测,可能依赖于星座占星学的API或算法。 6. 图片备份:让用户能够上传和存储图片,后台需提供...