字符串

  • 类型
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. Struts2自定义拦截器

    1. 需求 自定义拦截器实现,用户登录的访问控制. 2. 定义拦截器类 public class LoginInterceptor extends AbstractInterceptor { @Ove ...

  2. javascript void运算符

    参考链接:http://www.cnblogs.com/ziyunfei/archive/2012/09/23/2698607.html语法: void expr 作用:计算表达式expr,并返回un ...

  3. 3ds max不显示网格,转换为可编辑面片

    按G就消失了,快捷键 F3/F4切换线框和面片模式的显示

  4. oracle两时间相减得到相差的时间

    1.months_between(date1,date2);date1和date2相减得到相差的月份. select months_between(to_date('2015-05-11','yyyy ...

  5. qt_计算器的简单实现

    //阶乘不知道怎么实现不了/(ㄒoㄒ)/~~,以后慢慢调试吧......... //转换为后缀表达式,实现最主要功能 void MainWindow::toPostfix () { QString e ...

  6. Java动态代理一Proxy

    什么是动态代理? 动态代理可以提供对另一个对象的访问,同时隐藏实际对象的具体事实.代理一般会实现它所表示的实际对象的接口.代理可以访问实际对象,但是延迟实现实际对象的部分功能,实际对象实现系统的实际功 ...

  7. PHP常用函数大全。

    php usleep() 函数延迟代码执行若干微秒. unpack() 函数从二进制字符串对数据进行解包. uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 ID. time_sleep_ ...

  8. 阿里云的RDS 查看binlog日志的方法

    按时间点反后台备份的binlog日志从阿里云导出来,然后用mysqlbinlog查看日志内容: # mysqlbinlog -vv --base64-output=decode-rows mysql- ...

  9. IIS网站发布若干问题

    1.Win7 64位 IIS未能加载文件或程序集"System.Data.SQLite"或它的某一个依赖项   未能加载文件或程序集"System.Data.SQLite ...

  10. 18.中介者模式(Mediator Pattern)

    using System; namespace Test { class Program { /// <summary> /// 中介者模式,定义了一个中介对象来封装一系列对象之间的交互关 ...