字符串

  • 类型
var a = "abc";
var b = new String( a );
var c = Object( a ); typeof a; // "string"
typeof b; // "object"
typeof c; // "object" a instanceof String; // false
b instanceof String; // true
c instanceof String; // true Object.prototype.toString.call( a ); // "[object String]"
Object.prototype.toString.call( b ); // "[object String]"
Object.prototype.toString.call( c ); // "[object String]"
  • 字符串化(String)

    • 原始类型会返回其字符形式
    • Array,Function,Object, Date等会返回其自定义的toString方法的返回值;其中Object默认的是Object.prototype.toString(),即返回[object Object]

布尔类型

  • 布尔化(Boolean)
//除了下面的几种,其他都会转化为true
undefined
null
false
+0, -0, and NaN
""
//特殊
document.all //注意Boolean并没有调用toString,valueOf转化
Boolean([]) //true;
  • 判断
a || b;
// roughly equivalent to:
a ? a : b; a && b;
// roughly equivalent to:
a ? b : a;
........ // good enough (works implicitly):
if (a) {
// ..
} // better (works explicitly):
if (!!a) {
// ..
} // also great (works explicitly):
if (Boolean( a )) {
// ..
}

json字符化

JSON.stringify( "42" ); // ""42"" (a string with a quoted string value in it)
JSON.stringify( undefined ); // undefined
JSON.stringify( function(){} ); // undefined
JSON.stringify( [1,undefined,function(){},4] ); // "[1,null,null,4]"
JSON.stringify( { a:2, b:function(){} } ); // "{"a":2}"
  • 对于对象,如果包含不合法的json值或者其他问题,必须定义一个toJSON方法进行安全的操作;(所有实际上stringify就是字符串化toJSON返回的值)
var o = { };

var a = {
b: 42,
c: o,
d: function(){}
}; // create a circular reference inside `a`
o.e = a; // would throw an error on the circular reference
// JSON.stringify( a ); // define a custom JSON value serialization
a.toJSON = function() {
// only include the `b` property for serialization
return { b: this.b };
}; JSON.stringify( a ); // "{"b":42}"
  • 第二参数,用于选择/替换,为ArrayFunction;
var a = {
b: 42,
c: "42",
d: [1,2,3]
}; //选择对象属性 JSON.stringify( a, ["b","c"] ); // "{"b":42,"c":"42"}" JSON.stringify( a, function(k,v){
if (k !== "c") return v;
} );
// "{"b":42,"d":[1,2,3]}"
  • 第三参数,用于占为,应该为String
JSON.stringify( a, null, "-----" );
// "{
// -----"b": 42,
// -----"c": "42",
// -----"d": [
// ----------1,
// ----------2,
// ----------3
// -----]
// }"

特殊字符~

  • 效果相当于-(x + 1);

  • 用于判断indexOf: 由于没有查找到都返回-1, ~-1 = 0 // false;

  • 无进位去小数

Math.floor(54.5);     //54
Math.floor(-54.5); //-55
Math.ceil(54.5); //55
Math.ceil(-54.5); //-54
~~54.5 //54
~~-54.5 //-54

特殊字符+

  • 对象和原始类型或对象和对象进行时,会分别调用对象的valueOf, toString方法转化成原始类型后处理
var a = [1,2];
var b = [3,4]; a + b; // "1,23,4" //注意{}
{} + []; //0
({}) + []; //[object Object] //
var a = {
valueOf: function() { return 42; },
toString: function() { return 4; }
}; a + ""; // "42" String( a ); // "4"
  • 注意其他算术符号都是数值化的
'1' - 0; //1
[] * []; //0

比较

不严格相等

  • 数值和字符串判断,字符串转化为数值;
  • 任何值和布尔值判断,都转化为数值;
  • 只有undefinednull自我或相互判断时才相等
  • 对象和非对象判断,先将对象转化为原生类型(分别调用valueOf,toString)
"foo" == [ "foo" ];       // true
[] == ![]; // true
0 == "\n"; => 0 == " " // true //用于判断undefined和null
if (a == null) {
//...
}

大小比较

  • 数值/布尔值和其他类型比较,都先转化为数值;其他情况都先转化为字符串;
true > [] //true

//
var a = { b: 42 };
var b = { b: 43 }; a < b; // false
a > b; // false
a == b; // false
a <= b; // true => [object Object] == [object Object]
a >= b; // true

js整理2的更多相关文章

  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. js整理1

    数组 比较时的隐式转化 var a = [1,2,3]; var b = [1,2,3]; a == b; //false a == '1,2,3'; //true; // var c = []; B ...

  7. node.js整理 07例子

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

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

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

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

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

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

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

随机推荐

  1. jsonp注意事项

    自己测试的: <?php ');                     }                 }); } </script>     <!DOCTYPE htm ...

  2. linux初体验

    linux系统和window一样,也是一套独立的操作系统,它只是没有图形化界面而已

  3. JAVA addShutdownHook测试

    public static void main(String[] args) { System.out.println("1111111111"); try { Thread.sl ...

  4. chaper3_exerise_UVa455_周期串

    #include<iostream> #include<cstring> #include<stdio.h> using namespace std; ; int ...

  5. Gson 解析列表

    JsonArray jsonArray = new JsonParser().parse(resp).getAsJsonObject().getAsJsonArray("list" ...

  6. 《孙子算经》之"物不知数"题:中国剩余定理

    1.<孙子算经>之"物不知数"题 今有物不知其数,三三数之剩二,五五数之剩七,七七数之剩二,问物几何? 2.中国剩余定理 定义: 设 a,b,m 都是整数.  如果 m ...

  7. window 环境安装MongoDB

    强制安装mongodb服务 命令 sc create MongoDB binPath= "D:\MongoDB\Server\3.2\bin\mongod.exe --service --d ...

  8. NYOJ题目845无主之地1

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAskAAAKbCAIAAACIEYBGAAAgAElEQVR4nO3dvXKkPLe38X0Szn0gjv

  9. cache buffers

    buffers缓冲,可以型象的理解为漏斗.如果有大量的数据要写入磁盘,由于数据量很大,磁盘不能一下子接收,所以这个时候,就有了buffer这个漏斗,先把数据放入这个漏斗里面,然后让它慢慢的注入磁盘,这 ...

  10. WPF布局

    1.Canvas 布局控件 Canvas面板是最轻量级的布局容器,它不会自动调整内部元素的排列和大小,不指定元素位置,元素将默认显示在画布的左上方.Canvas主要用来画图.Canvas默认不会自动裁 ...