数组

  • 比较时的隐式转化
var a = [1,2,3];
var b = [1,2,3]; a == b; //false
a == '1,2,3'; //true; //
var c = [];
Boolean(c); //true
c == false; //true
c == 0; //true
c == ''; //true
c == undefined; //false
  • 类数组
var arr = Array.prototype.slice.call( arguments );
//es6
var arr = Array.from( arguments );
  • 字符串使用数组方法
var a = "foo";

var c = Array.prototype.join.call( a, "-" );
var d = Array.prototype.map.call( a, function(v){
return v.toUpperCase() + ".";
} ).join( "" ); c; // "f-o-o"
d; // "F.O.O." //
var c = Array.prototype.reverse.call( a ); //error var c = a.split( "" ).reverse().join( "" );
  • 关于undefined
var a = [ undefined, undefined, undefined ];  //[ undefined, undefined, undefined ]
var b = new Array( 3 ); //[ undefined x 3 ]
var c = [];
c.length = 3; //[ undefined x 3 ]
var d = [ , , , ]; //[ undefined x 3 ] a.join( "-" ); // "--"
b.join( "-" ); // "--" a.map(function(v,i){ return i; }); // [ 0, 1, 2 ]
b.map(function(v,i){ return i; }); // [ undefined x 3 ] //确实想要表示多个空值而不是不存在;
var a = Array.apply( null, { length: 4 } );
a; // [ undefined, undefined, undefined ,undefined]

数值

  • 浮点数精确度
0.1 + 0.2 === 0.3; // false

//

if (!Number.EPSILON) { //es6
Number.EPSILON = Math.pow(2,-52);
}
function numbersCloseEnoughToEqual(n1,n2) {
return Math.abs( n1 - n2 ) < Number.EPSILON;
} var a = 0.1 + 0.2;
var b = 0.3; numbersCloseEnoughToEqual( a, b ); // true
numbersCloseEnoughToEqual( 0.0000001, 0.0000002 ); // false
  • 判断正负0
function isNegZero(n) {
n = Number( n );
return (n === 0) && (1 / n === -Infinity);
}
  • 数值化(Number)

    • 对于原始类型: false//0, true//1, null//0, 数值字符串//数值, 其他//NaN;
    • 对于其他类型: 调用其valueOf, toString,对返回的原始类型进行操作;否则报错;
Number( "" );           // 0
Number( [] ); // 0
  • 小心使用parseInt, 它也会调用内部的toString方法;
parseInt( 1/0, 19 ); =>parseInt( "Infinity", 19 ) => parseInt( "I", 19 ) // 18;

parseInt( 0.000008 );       // 0   ("0" from "0.000008")
parseInt( 0.0000008 ); // 8 ("8" from "8e-7")
parseInt( false, 16 ); // 250 ("fa" from "false")
parseInt( parseInt, 16 ); // 15 ("f" from "function..") parseInt( "0x10" ); // 16
parseInt( "103", 2 ); // 2

对象

  • 对象引用
//引用被切断
function foo(x) {
x.push( 4 );
x; // [1,2,3,4] // later
x = [4,5,6]; //改变arg[x]的引用
x.push( 7 );
x; // [4,5,6,7]
} var a = [1,2,3]; foo( a ); a; // [1,2,3,4] not [4,5,6,7] //引用一直保存
function foo(x) {
x.push( 4 );
x; // [1,2,3,4] // later
x.length = 0; // empty existing array in-place
x.push( 4, 5, 6, 7 );
x; // [4,5,6,7]
} var a = [1,2,3]; foo( a ); a; // [4,5,6,7] not [1,2,3,4] //注意特殊对象的隐式转化
function foo(x) {
x = x + 1;
x; // 3
} var a = 2;
var b = new Number( a ); // or equivalently `Object(a)` foo( b );
console.log( b ); // 2, not 3

void操作符

  • 使不返回任何值
//可能用到的情况
function doSomething() {
// note: `APP.ready` is provided by our application
if (!APP.ready) {
// try again later
return void setTimeout( doSomething, 100 );
} var result; // do some other stuff
return result;
}

等值判断

//es6
Object.is( a,b ); 不用于严格意义的对比,而是用于特殊例子的比较 var a = 2 / "foo";
var b = -3 * 0; Object.is( a, NaN ); // true
Object.is( b, -0 ); // true Object.is( b, 0 ); // false

预定义数值

if(VALUE) {
console.log('value');
} //error if(typeof VALUE !== "undefined") {
console.log('value')
} //
function () {
var newValue = (typeof oldValue !== "undefined") ? oldValue : 'newvalue';
...
} function (oldValue) {
var newValue = oldValue || 'newvalue';
...
}

js原生类型

  • String()
  • Number()
  • Boolean()
  • Array()
  • Object()
  • Function()
  • RegExp()
  • Date()
  • Error()
  • Symbol() -- added in ES6!
由于所有类型的本源都是来自Object(),使用Object.prototype.toString.call方法可以现在类型内部的[[class]];
格式为[object X]
  • 构建时注意
//Object
var a = new Object();
var b = Object();
var c = new Object; //Array
var a = new Array();
var b = Array();
var c = new Array; //Date
var a = new Date(); //[object Date];
var b = Date(); //string
var c = new Date; //[object Date];
  • 各个类型的原型都是其相对应类型的空值;//注意不要污染它们;
Array.prototype; //[];
......

js整理1的更多相关文章

  1. Dynamics CRM 日常使用JS整理(二)

    BPF(Business Process Flow)相关的JS 为Stage添加changed或者selected事件: function fnOnLoad() { Xrm.Page.data.pro ...

  2. Dynamics CRM 日常使用JS整理(一)

    整理下平时CRM开发中用到的一些基本的js操作 取值: var oResult = Xrm.Page.getAttribute(sFieldName).getValue(); var oResult ...

  3. js整理

    Js脚本语音 网页里面使用的脚本语音 基础语法 注释语法  单行注释// 多行注释/**/ 嵌入js代码  尽量靠下写  用<script type="text/javascript& ...

  4. Vue.js 整理笔记

    以前我们用Jquery进行dom的操作,虽然熟悉后开发效率很高,但是如果多个控件的相互操作多的情况下,还是会乱.相比之下,Vue的使用更加清晰,通过虚拟dom将数据绑定,而且组件化和路由的帮助下,让整 ...

  5. js整理3

    函数 call: fun.call(a), a会转化成相应的对象,函数内的this即指向它; function foo() { console.log(this); } foo.call(null); ...

  6. node.js整理 07例子

    需求 一个简单的静态文件合并服务器,该服务器需要支持类似以下格式的JS或CSS文件合并请求. http://assets.example.com/foo/??bar.js,baz.js 在以上URL中 ...

  7. node.js整理 06异步编程

    回调 异步编程依托于回调来实现,但不能说使用了回调后程序就异步化了 function heavyCompute(n, callback) { var count = 0, i, j; for (i = ...

  8. node.js整理 05进程管理

    简介 NodeJS可以感知和控制自身进程的运行环境和状态,也可以创建子进程并与其协同工作,这使得NodeJS可以把多个程序组合在一起共同完成某项工作,并在其中充当胶水和调度器的作用 常用API Pro ...

  9. node.js整理 03文件操作-遍历目录和文本编码

    遍历目录 递归算法 遍历目录时一般使用递归算法,否则就难以编写出简洁的代码. 递归算法与数学归纳法类似,通过不断缩小问题的规模来解决问题 function factorial(n) { if (n = ...

随机推荐

  1. 【python】入门学习(五)

    字符串: 正索引,从0开始 和 负索引,从-1开始 >>> s = 'apple' >>> s[0] 'a' >>> s[1] 'p' >& ...

  2. cocos2d-x 第一篇 环境搭建

    官网:http://www.cocos2d-x.org/ 下载一个稳定版的cocos2d-x (网址:http://download.cocos2d-x.org/ Github Repository ...

  3. PHP try catch

    本文转载自百度知道 http://zhidao.baidu.com/link?url=Wi5EOXIf12yBp9d_4VoFHCUFtlTPcZJ0sxidLspV6P7qAqYMap3IC6dXE ...

  4. iOS 全局禁止横屏,但UIWebView 全屏播放视频,横屏,解决办法(任意页面横竖屏或禁止)

    iOS 全局禁止横屏,但UIWebView 全屏播放视频,横屏,解决办法 时间 2015-07-14 20:59:00  博客园-原创精华区 原文  http://www.cnblogs.com/fe ...

  5. MVC4 @RenderBody、@RenderSection、@RenderPage、Html.RenderPartial、Html.RenderAction的作用和区别

    1. RenderBody在Razor引擎中没有了“母版页”,取而代之的是叫做“布局”的页面(_Layout.cshtml)放在了共享视图文件夹中.在这个页面中,会看到标签里有这样一条语句:@Rend ...

  6. 将rabbitmq整合到Spring中手动Ack

    如果要手动ack,需要将Listener container 的 acknowledge 设置为manul,在消费消息的类中需实现ChannelAwareMessageListener接口. over ...

  7. android app 内部文件路径

    public class MainActivity extends Activity { final String FILE_NAME = "crazyit.bin"; @Over ...

  8. Http返回码

    HTTP协议状态码表示的意思主要分为五类 ,大体是 :   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~   1×× 保留    2×× 表示请求成功地接收    3×× 为完成请求客户需 ...

  9. Pyqt QSS简单的Ui美化

    什么是QSS QSS 是Qt StyleSheet 的简称,意思就是qt的样式表格,StyleSheet 可以像CSS一样的写样式.使页面美化跟代码层分开,利于维护. QSS的语法 同css一样,他也 ...

  10. gcc【数学几何】

    GCC Time Limit: 1000MS Memory limit: 65536K 题目描述 The GNU Compiler Collection (usually shortened to G ...