总结两个Javascript的哈稀对象的一些编程技巧_javascript技巧
我喜欢从最基础的内容讲起,然后慢慢深入,高手可能要给点耐心啊。
先看一个最简单的应用。在下面的代码中,我们需要实现一个功能,就是点击每个按钮显示相应的网址
那么。怎么写这个 showUrl函数呢? 我想大多数人可能会这样写.
<script> <BR>// by Go_Rush(阿舜) from http://ashun.cnblogs.com/ <BR>function showUrl(element){ <BR> var url; <BR> switch (element.value){ <BR> case "百度": url="http://www.baidu.com/" ;break; <BR> case "Google": url="http://www.google.com/" ;break; <BR> case "微软": url="http://www.microsoft.com/";break; <BR> case "博客园": url="http://www.cnblogs.com/" ;break; <BR> case "阿舜的博客": url="http://ashun.cmblogs.com/" ;break; <BR> default: url="" <BR> } <BR> alert(url) <BR>} <BR></script>
这样写不太好,原因有二:
1.写太长,很麻烦,用if, switch 语句来写,如果有100个条件,那岂不要写100个语句
2.不便于维护和扩展,如果需求经常变化,那些数据从数据库来怎么办,每变一下都要改程序的逻辑结构
对JavaScript比较有经验的程序员肯定不会这样写,一般用数组来实现。 可以是二维数组,也可以是双数组
1.双数组方法
<script> <BR>// by Go_Rush(阿舜) from http://ashun.cnblogs.com/ <BR>var arrText=["百度","Google","微软","博客园","阿舜的博客"]; <BR>var arrUrl=["http://www.baidu.com/","http://www.google.com/","http://www.microsoft.com/","http://www.cnblogs.com/","http://ashun.cmblogs.com/"] <BR>function showUrl(element){ //用双数组方法 <BR> var value=element.value; <BR> for(var i=0;i<arrText.length;i++){ <BR> if (arrText[i]===value) return alert(arrUrl[i]) <BR> } <BR>} <BR></script>
2. 二维数组方法
<script> <BR>// by Go_Rush(阿舜) from http://ashun.cnblogs.com/ <BR>var arr=[ <BR> ["百度" ,"http://www.baidu.com/"], <BR> ["Google" ,"http://www.google.com/"], <BR> ["微软" ,"http://www.microsoft.com/"], <BR> ["博客园" ,"http://www.cnblogs.com/"], <BR> ["阿舜的博客" ,"http://ashun.cmblogs.com/"] <BR>]; <BR>function showUrl(element){ //用二维数组方法 <BR> var value=element.value; <BR> for(var i=0;i<arr.length;i++){ <BR> if (arr[i][0]===value) return alert(arr[i][1]) <BR> } <BR>} <BR></script>
以上两种方法借用数组作为数据结构,实现了程序要求的功能,而且为以后的扩展,变动做好了充分的准备
但是,效率呢? 每次都要遍历数组,每次都要判断。。。。
下面,我来介绍一种不用数组,不用循环遍历,也不要判断比较的方法。
先来一段:
<script> <BR>// by Go_Rush(阿舜) from http://ashun.cnblogs.com/ <BR>var hash={ <BR> "百度" :"http://www.baidu.com/", <BR> "Google" :"http://www.google.com/", <BR> "微软" :"http://www.microsoft.com/", <BR> "博客园" :"http://www.cnblogs.com/", <BR> "阿舜的博客" :"http://ashun.cmblogs.com/" <BR>}; <BR>function showUrl(element){ //使用哈稀对象 <BR> alert(hash[element.value]) <BR>} <BR></script>
看到没有,以前要用循环的,要用判断的函数,现在只要一行代码就OK了,而且扩展性还是最好的。
如果您对JavaScript比较熟悉,您一定会对数组情有独钟,因为它确实是一种非常方便,应用非常广泛的
数据结构,但是对于哈稀对象这个青苹果,哪怕您只啃过它一口,你一定永远不会忘记它的甜美。
他作为一种数据结构,在许多场合可以简化编程,在海量数据面前,他的性能要远远高于数组。(这个在
我日后的po文里面会提到的,请关注)
他作为一种对象,可以在JavaScript实现类,模拟面向对象编程。
以上讲得非常简单,仅作为抛砖引入,大家有兴趣的可以在回复里面谈谈自己的应用心得啊。
临走之前再讲个例子----判断上传的文件是否为图像文件.
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

本教程向您展示了如何将自定义的Google搜索API集成到您的博客或网站中,提供了比标准WordPress主题搜索功能更精致的搜索体验。 令人惊讶的是简单!您将能够将搜索限制为Y

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

核心要点 JavaScript 中的 this 通常指代“拥有”该方法的对象,但具体取决于函数的调用方式。 没有当前对象时,this 指代全局对象。在 Web 浏览器中,它由 window 表示。 调用函数时,this 保持全局对象;但调用对象构造函数或其任何方法时,this 指代对象的实例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。这些方法使用给定的 this 值和参数调用函数。 JavaScript 是一门优秀的编程语言。几年前,这句话可

jQuery是一个很棒的JavaScript框架。但是,与任何图书馆一样,有时有必要在引擎盖下发现发生了什么。也许是因为您正在追踪一个错误,或者只是对jQuery如何实现特定UI感到好奇

该帖子编写了有用的作弊表,参考指南,快速食谱以及用于Android,BlackBerry和iPhone应用程序开发的代码片段。 没有开发人员应该没有他们! 触摸手势参考指南(PDF) Desig的宝贵资源
