JavaScript实用技巧(一) |
本文标签:JavaScript,实用技巧 JavaScript 的成功让人津津乐道,为 Web 网页编写 JavaScript 代码已经是所有 Web 设计师的基本功,这门有趣的语言蕴藏着许多不为人熟知的东西,即使多年的 JavaScript 程序员,也未能完全吃透 。本文从7个方面讲述 JavaScript 中那些你不很熟知但非常实用的技巧 。 简略语句 var car = new Object(); car.colour = red; car.wheels = 4; car.hubcaps = spinning; car.age = 4; 可以使用简略语句如下: var car = { colour:red, wheels:4, hubcaps:spinning, age:4 } 对象 car 就此创建,不过需要特别注意,结束花括号前一定不要加 ";" 否则在 IE 会遇到很大麻烦 。 var arrayTest = new Array( test1,test2,test3,test4 ); 使用简略语句则: var arrayTest = [test1,test2,test3,test4]; 另一个可以使用简略语句的地方是条件判断语句: var direction; if(x < 200){ direction = 1; }else{ direction = -1; } //可以简略为: var direction = x < 200 ? 1 : -1; JSON 数据格式 JSON 是 "JavaScript Object Notation" 的缩写,由 Douglas Crockford 设计,JSON 改变了 JavaScript 在缓存复杂数据格式方面的困境,如下例,假如你要描述一个乐队,可以这样写: var band = { "name":"My name is test1", "Members":[ {"name":"name1","role":"role1"}, {"name":"name2","role":"role2"}, {"name":"name3","role":"role3"}, {"name":"name4","role":"role4"} ], "year":"2010" } 你可以在 JavaScript 中直接使用 JSON,甚至作为某些 API 的返回数据对象,以下代码调用著名书签网站 delicious.com 的一个 API,返回你在该网站的所有书签,并显示在你自己的网站: <div id="delicious"></div> <script> function delicious(o){ var out = <ul>; for(var i = 0;i<o.length;i++){ out +=<li><a href="+o[i].u+">+o[i].d+</a></li>; } out += </ul>; document.getElementById(delicious).innerHTML = out; } </script> <script src="http://feeds.delicious.com/v2/json/codepo8/javascript?count=15&callback=delicious"></script> JavaScript 本地函数 (Math, Array 和 String) var numbers = [3,342,23,22,124]; var max = 0; for(var i = 0;i<numbers.length;i++){ if(numbers[i] > max){ max = numbers[i]; } } alert(max); 使用内置函数可以更容易实现: var numbers = [3,342,23,22,124]; numbers.sort(function(a,b){return b - a}); alert(numbers[0]); 另一个方法是使用 Math.max() 方法: Math.max(12,123,2,3,422,4);//return 422 你可以用这个方法帮助探测浏览器 var scrollTop = Math.max(doc.documentElement.scrollTop,doc.body.scrollTop); 这解决了 IE 浏览器的一个问题,通过这种方法,你总是可以找到那个正确的值,因为浏览器不支持的那个值会返回 undefined 。 function addclass(elm,newclass){ var c = elm.className; elm.className = (c == )?newclass: c+ +newclass; } 使用 split 和 join 方法则直观优雅得多: function addclass(elm,newclass){ var classes = elm.className.split( ); classes.push(newclass); elm.className = classes.join( ); } 事件代理
你应当在最后一步做这项工作,这里有一个文章,交付代码前的5件事值的参考 。 同后台交互 JavaScript 是一门前台语言,你需要别的语言同后台交互,并返回数据,使用 AJAX,你可以让 JavaScript 直接使用同后台的交互,将复杂的数据处理交由后台处理 。 JavaScript 框架 自己编写适应各种浏览器的代码是完全浪费时间,应当选择一个 JavaScript 框架,让这些复杂的事情交给框架处理 。 |