(第二章)改善JavaScript,编写高质量代码。
建议34:字符串是非值操作
var a = "javascript";
var b = a;
b = b.toUpperCase();
alert(a); //javascript;
alert(b); //JAVASCRIPT;
建议34
建议35:获取字节长度
String.prototype.lengthBD = function(){
var b = ; l = this.length;
if(l){
for(var i = ; i < l; i++){
if(this.charCodeAt(i) > ){
b+=;
}else{
b++;
}
}
return b;
}else{
return ;
}
} var s= "String对象长度";
alert(s.lengthDB()); //14 中文为2个数字
建议35
建议36:警惕字符串链接操作
当连接少量字符串时,例如:
str += "one" + " two";
JavaScript在执行这行代码时会进行以下4个步骤:
第一步,在内存中创建一个临时字符串。
第二步,临时字符串的值被赋予"onetwo",
第三步,临时字符串与str的值进行连接,
第四步,把结果赋予str。
不过,通过下面的代码进行优化能够提高执行效率,两个离散表达式直接将内容附加到str上,避免了临时字符串(第一步和第二步),这样做可以使执行速度提高10%~40%;
str += "one";
str += "two";
实际上,也可以用以下一行代码实现同样的性能提高,例如:
str = str + "one" + "two";
也就是说 str要在开头,如str = "one" + str + "two" 就会失去这种优化。
建议36
建议37:推荐使用replace
replace方法同时执行查找和替换两个操作。
var s = "javascript";
var b = s.replace(/(java)(script)/,"$2-$1");
alert(b); // "script-java";
1.$1、$2、...、$99:与正则表达式中的第1~99个子表达式相匹配的文本。
2.$&:与正则表达式相匹配的子字符串。
3.$`:位于匹配字符串左侧的文本。
4.$':位于匹配字符串右侧的文本。
5.$$:表示$符号。
建议37
建议38:正确认识正则表达式工作机制
建议39:正确理解正则表达式回溯
建议40:正确使用正则表达式分组
建议41:正确使用正则表达式引用
建议42:用好正则表达式静态值
建议43:使用exec增强正则表达式功能
建议44:正确使用原子组
建议45:警惕嵌套量词和回溯失控
建议46:提高正则表达式执行效率
建议47:避免使用正则表达式的场景
建议48:慎用正则表达式修剪字符串
建议49:比较数组与对象同源特征
建议50:正则检测数组类型
建议51:理解数组长度的有限性和无限性
建议52:建议使用splice删除数组
var number = ['zero','one','two','three','four','five'];
delete numbers[2];
number = ['zero','one',undefined,'three','four','five']; var number = ['zero','one','two','three','four','five'];
numbers.splice(2,1);
number = ['zero','one','three','four','five']; 这对大型数组来说效率会更高。
建议52
建议53:小心使用数组维度
建议54:增强数组排序的sort功能
//从小到大排序
function f(a,b){
return (a-b)
}
var a = [3,1,2,4,5,7,8,0,9,6];
a.sort(f);
alert(a); // [0,1,2,3,4,5,6,7,8,9]; //从大到小排序
function f(a,b){
return -(a-b)
}
var a = [3,1,2,4,5,7,8,0,9,6];
a.sort(f);
alert(a); // [9,8,7,6,5,4,3,2,1,0]; //根据奇偶性质排列数组 奇数在前
function f(a,b){
var a = a%2;
var b = b%2;
if(a==0){return 1;}
if(b==0){return -1;}
}
var a = [3,1,2,4,5,7,6,8,0,9];
a.sort(f);
alert(a); //[3,1,5,7,9,0,8,6,4,2]; //根据奇偶性质排列数组 偶数在前
function f(a,b){
var a = a%2;
var b = b%2;
if(a==0){return -1;}
if(b==0){return 1;}
}
var a = [3,1,2,4,5,7,6,8,0,9];
a.sort(f);
alert(a); //[0,8,6,4,2,6,8,3,1,5,7,9];
建议54
建议55:不要拘泥于数字下标
var a = [];
a[-1] = 1; //为下标位-1的元素赋值
很明显,上面的用法是非法的。因为这不符合语法规范,使用length属性检查,返回值为0,说明数组并没有增加长度,这是正确的,也是正常的,但是,使用下面的方法可以读取该元素的值。
alert(a.length); // 0
alert(a[-1]);
alert(a["-1"]);
建议55
建议56:使用arguments模拟重载
(第二章)改善JavaScript,编写高质量代码。的更多相关文章
- 编写高质量代码:改善Java程序的151个建议(第二章:基本类型)
编写高质量代码:改善Java程序的151个建议(第二章:基本类型) 目录 建议21:用偶判断,不用奇判断 建议22:用整数类型处理货币 建议23:不要让类型默默转换 建议24:边界还是边界 建议25: ...
- (第一章)改善JavaScript,编写高质量代码。
根据<编写高质量代码改善JavaScript程序的188个建议>这本书,来记录我目前所了解的建议方式. 建议1:警惕Unicode乱码 根据ECMA标准规定JavaScript语言可以使用 ...
- 编写高质量代码:改善Java程序的151个建议(第一章:JAVA开发中通用的方法和准则)
编写高质量代码:改善Java程序的151个建议(第一章:JAVA开发中通用的方法和准则) 目录 建议1: 不要在常量和变量中出现易混淆的字母 建议2: 莫让常量蜕变成变量 建议3: 三元操作符的类型务 ...
- 编写高质量代码改善python程序91个建议学习01
编写高质量代码改善python程序91个建议学习 第一章 建议1:理解pythonic的相关概念 狭隘的理解:它是高级动态的脚本编程语言,拥有很多强大的库,是解释从上往下执行的 特点: 美胜丑,显胜隐 ...
- 编写高质量代码改善C#程序的157个建议——建议4: TryParse比Parse好
建议4: TryParse比Parse好 如果注意观察除string外的所有基元类型,会发现它们都有两个将字符串转型为本身的方法:Parse和TryParse.以类型double为例,这两个方法最简单 ...
- 编写高质量代码改善C#程序的157个建议——导航开篇
前言 由于最近工作重心的转移,原来和几个同事一起开发的项目也已经上线了,而新项目就是在现有的项目基础上进行优化延伸扩展.打个比方,现在已经上线的项目行政案件的Web管理网站(代码还没那么多相比较即将要 ...
- 编写高质量代码--改善python程序的建议(六)
原文发表在我的博客主页,转载请注明出处! 建议二十八:区别对待可变对象和不可变对象 python中一切皆对象,每一个对象都有一个唯一的标识符(id()).类型(type())以及值,对象根据其值能否修 ...
- 编写高质量代码--改善python程序的建议(八)
原文发表在我的博客主页,转载请注明出处! 建议四十一:一般情况下使用ElementTree解析XML python中解析XML文件最广为人知的两个模块是xml.dom.minidom和xml.sax, ...
- 编写高质量代码改善java程序的151个建议——导航开篇
2014-05-16 09:08 by Jeff Li 前言 系列文章:[传送门] 下个星期度过这几天的奋战,会抓紧java的进阶学习.听过一句话,大哥说过,你一个月前的代码去看下,慘不忍睹是吧.确实 ...
- 编写高质量代码改善C#程序的157个建议[1-3]
原文:编写高质量代码改善C#程序的157个建议[1-3] 前言 本文主要来学习记录前三个建议. 建议1.正确操作字符串 建议2.使用默认转型方法 建议3.区别对待强制转换与as和is 其中有很多需要理 ...
随机推荐
- PECL: configuration option "php_ini" is not set to php.ini location
message similar to: configuration option "php_ini" is not set to php.ini locationYou shoul ...
- Python rest-framework 中类的继承关系(as_view)
一. 背景 最近几天一直在学习restful framework的源代码,用户请求的流程,在路由系统这块遇到一个疑问,关于类的继承关系,当请求进来到路由这块,执行as_view()方法的时候,为什么会 ...
- 深入浅出图解【计算机网络】 之 【TCP可靠传输的实现2: 超时重传+拥塞控制】
[前言]上一篇文章介绍了关于TCP的基础知识,以及建立(释放)连接和滑动窗口的概念. 本篇文章将延续上一篇的思路,继续介绍TCP实现可靠传输的机制. 超时重传 上一篇文章里介绍过TCP采用停止等待协议 ...
- 仿ElementUI构建自己的Vue组件库用babel-plugin-component按需加载组件及自定义SASS主题
最近使用ElementUI做项目的时候用Babel的插件babel-plugin-component做按需加载,使得组件打包的JS和CSS包体积大大缩小,加载速度也大大提升,所有想模仿做一个组件库也来 ...
- Spring 中使用XML配置方式和使用注解方式实现DI
Spring容器给我们提供了很好的环境,我们只关注主要业务即可,其他的无需关注太多.今天刚学的DI DI(Dependency Injection):依赖注入 使用XML配置文件完成依赖注入 1.1普 ...
- centos 快速安装wordpress
1.两种方式得到Wordpress 首先你可以去wordpress官方网站看下最新的wordpress的下载地址多少.比如wordpress 3.9.1的下载地址是: http://cn.wordpr ...
- ArcGis实现画矩形(RectangleFeedBack)
private void axMapControl1_OnMouseDown(object sender, IMapControlEvents2_OnMouseDownEvent e) ...
- Atitit.播放系统的选片服务器,包厢记时系统 的说明,教程,维护,故障排查手册p825
Atitit.播放系统的选片服务器,包厢记时系统 的说明,教程,维护,故障排查手册p825 1. 播放系统服务器方面的维护2 1.1. 默认情况下,已经在系统的启动目录下增加了俩个启动项目2 1.2. ...
- springboot 文件上传 java.io.IOException: The temporary upload location [/tmp/xx] is not valid
转自:http://meia.fun/article/1541578061808 首先分析下出现问题的原因:linux 下的 /tmp 目录,是用来存储由各种程序创建的临时文件的地方.一些配置,导致系 ...
- IDEA 导入javaWeb项目
导入后的项目 1. 把项目变成web项目 配置 artifact 然后这边就自动配置成了 tomcat: 然后运行 没有毛病!!