字符串

  • 类型
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. Hadoop 分布式文件系统:架构和设计

    引言 Hadoop分布式文件系统(HDFS)被设计成适合运行在通用硬件(commodity hardware)上的分布式文件系统.它和现有的分布式文件系统有很多共同点.但同时,它和其他的分布式文件系统 ...

  2. JavaScript高级程序设计学习笔记--基本概念

    1.语句 ECMAScript中的语句以一个分号结尾:如果省略分号,则由解析器确定语句的结尾,如下例所示: var sum=a+b //即使没有分号也是有效的语句--推荐 var diff=a-b; ...

  3. 3.UNION

    --联合结果集union(集合运算符-- group by StudentNo union ---union可以合并多个结果集 --它有两个前提和一个注意: --1.合并的结果集的列数必须完全一致 - ...

  4. [页面滚动到底部]jquery $(window).height()取值等于$(document).height()的问题

    问题现象:JSP中头部引用了某个head.jsp,在videoList.jsp中生成片段时如下 实际最终生成的HTML如下: <!DOCTYPE html>没有解析到,原因找到了,先想办法 ...

  5. php命令行运行出现错误Call to undefined function curl_init()

    在windows命令行窗口下运行php命令,需要将php.exe所在的路径添加到Path环境变量,例如C:\wamp\bin\php\php5.4.3 启动Apache服务 在命令行中输入php te ...

  6. WaxPatch中demo注意问题

    问题一 https://github.com/mmin18/WaxPatch网址中提供的demo是可以运行,但是存在一个问题,如果把patch.zip换成自己的并且上传到自己的服务器(github), ...

  7. [Android] 关于getinstalledpackages参数的分析

    reference to  : http://blog.csdn.net/luojiusan520/article/details/47696891 getinstalledpackages()的方法 ...

  8. September 10th 2016 Week 37th Saturday

    An innovation that goes beyond imagination again raised the standard. 颠覆想象的创新,再一次刷新标准. An advertisem ...

  9. 关于Linux环境变量

    查看全局变量:  printenv 查看单个环境变量的值可以用echo命令,必须在环境变量的名称前放一个$符号 如:

  10. NYOJ之猴子吃桃问题

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAskAAAIMCAIAAACIcqa9AAAgAElEQVR4nO3dO3Li3BaG4TMJcgbi1A