摘要: 标题有些说不明白,意思是这样的:给定一个数字,然后将其倒置,再和原来的数相加,得出的数如果不是回文数,则将新的和倒置,再和原来的数相加,以此循环,直到求出和为回文数,并输出整个过程。 这个过程有2个技术点:1. 将数字倒置;2. 判断数字是否是回文数。我这里偷了懒,利用的是将数字看作是字符串,所以实现起来,难度不大。1. 将数字倒置:1 function getPostNumber(num) {2 var postNumber = [];3 for(var i = 0; i < num.length; i++) {4 postNumber.push(num... 阅读全文
posted @ 2012-03-23 23:53 bilipan 阅读(262) 评论(0) 推荐(0) 编辑
摘要: 文件上传很常见,也有好些方法,不过我见过的大多是基于flash的,也有用XMLhttpResponse来提交文件的,其实大可不必这么麻烦,我这里介绍一种更具兼容性的用法,利用iframe来曲线实现无刷新页面文件上传功能,这种方法其实也很常见了。 iframe上传文件原理是这样的:首先input file控件本身是被表单包含的,表单属性必须设置为enctype="multipart/form-data",才能上传任意文件。但是仅仅有这个还不行, 因为提交表单后,它会自动刷新页面,为了不让它离开本页,我们可以在这个提交的页面上动态生成一个隐藏的iframe,但是别忘了在表单上再 阅读全文
posted @ 2012-03-22 18:03 bilipan 阅读(571) 评论(0) 推荐(1) 编辑
摘要: 有时候需要实现一个功能,使得数据以不同的方式显示,好像有点说不清楚,举个例子吧。比如:给定一个包含了所有课程的数据,在A页面上是一种排版方式,在B页面上是另外一种排版方式,这时候可以采用模板的方式将数据渲染到页面上。但是这就涉及到一个模板的创建和解析的问题。 我这里自定义了在html标签中嵌入变量的方式是这样的:<div>{list}</div>,等渲染到页面时,将{}所包含的变量转换为具体的值,这样就可以简单实现模板解析的过程。那如何将其中的变量转换为实际值呢?一种简易的方式是通过正则表达式,将{list}变为list,然后再对其赋值。具体方法如下:1 var tem 阅读全文
posted @ 2012-03-11 03:37 bilipan 阅读(2171) 评论(0) 推荐(0) 编辑
摘要: 在用原生js创建dom标签后,无法多次添加子标签,感觉非常奇怪,于是查看appendChild()的用法。 通常添加子标签的方式是这样的: 1 parentElem.appendChild(subElem); 但是要注意的是: 在添加前,subElem必须存在,不一定是显示到页面内,但一定要被创建。但是出现问题的根本所在是下一条:如果subElem已经被添加了,那么,再执行添加操作时,不会再被添加,只会更改subElem的位置状态,什么意思呢?比如: 页面内只有1个div1, 此时若第一次添加新的标签div2到页面body内,则div2会排在div1的后面,与div1属于平级。如果... 阅读全文
posted @ 2012-03-06 17:24 bilipan 阅读(1672) 评论(0) 推荐(0) 编辑