1、toString()方法:数值、布尔值、对象以及字符串本身都有toString()方法,但null和undefined没有这个方法。
默认情况下,toString()以十进制格式返回数值的字符串表示,可以传递一个参数,来返回以二进制,八进制,十六进制,甚至其他任何有效进制格式表示的字符串值
alert('这是字符串'.toString());//返回"这是字符串"
var number = 1299;
alert(number.toString());//返回字符串"1299";
//1299.toString(),这种写法错误
//利用toString()转换进制
alert(number.toString(16))//转换成2进制,返回513
alert(number.toString(8))//转换成2进制,返回2423
alert(number.toString(2))//转换成2进制,返回10100010011
alert(true.toString());//返回字符串"true",false返回字符串"false"
alert({"type":"object"}.toString());//不能转换成字符串
alert([0,1].toString());//返回字符串"0,1"
alert("".toString())//返回""空字符串
alert(NaN.toString());//返回字符串 "NaN"
//注意:null和undefined 没有toString方法
alert(undefined.toString());//不返回值
alert(null.toString())//不返回值
2、String()方法:强制转换成字符串。在不知道转换的值是不是null或undefined的时候,可能用String()方法,String()方法可以把任何类型的值转换成字符串
alert(String(null)) //返回字符串"null"
alert(String(undefined))//返回字符串"undefined"
//其他数据类型跟toString()转换的一样
1、用Number()方法:强制转换成数字,遵循下列规则
//如果是Boolean值,true和false分别转换成1和0
alert(Number(true));//返回1
alert(Number(false));//返回0
alert(Number(null));//返回0
alert(Number(undefined));//返回NaN
//如果是字符串,会忽略前导0,并以十进制格式返回
alert(Number(""));//返回0
alert(Number("011"));//返回11
alert(Number("01.1"));//返回1.1
alert(Number("0xf"));//括号中为有效的十六进制值,返回等值的十进制值 :15
//如果是对象,则先调用valueOf(),再调用toString()
alert(Number({}));//返回NaN
alert(Number([1,2]));//返回NaN
2、parseInt()方法:一般用于处理字符串,转换成整数,它会忽略字符串前的空格。如果第一个字符不是数字字符或负号,parseInt()会返回NaN
alert(parseInt("12306blue")); //返回12306
alert(parseInt("-12306blue")); //返回-12306
alert(parseInt("")); //返回NaN
alert(parseInt("0xA")); //返回10(十六进制)
alert(parseInt("22.2")); //返回22
alert(parseInt("070")); //返回56(八进制)
alert(parseInt("70")); //返回70 (十进制
alert(parseInt(true));//返回NaN
alert(parseInt(null));//返回NaN
alert(parseInt(NaN)); //返回NaN
alert(parseInt([3,2]));//返回3,先把数组转换成字符串,再返回数字
alert(parseInt(["a",2])); //返回NaN,因为转换成字符串后,第一个字符不是数字字符
alert(parseInt({"type":"object"}));//返回NaN
alert(parseInt({0:"object"}));//返回NaN
alert(parseInt(undefined));//返回NaN
parseInt()转换十六进制时,可能会判断错误,返回NaN,这时可以为parseInt()设置第二个参数,指定要转换的基数,如下:
alert(parseInt("AF")); //返回NaN
alert(parseInt("AF",16));//返回175
3、parseFloat():转换成浮点数 ,浮点类型没有基数模式(即没有第二个参数,只能转换十进制值)
使用parseFloat需要注意以下几点:
a.与parseInt()一样,也是从第一个字符开始解析,如果第一个字符不是数字或负号或点(.)号【parseInt()中,第一个字符为点号时返回NaN】,则返回NaN
b.parseFloat()会忽略前导所有的”0”
alert(parseFloat(""));//返回NaN
alert(parseFloat(NaN));//返回NaN
alert(parseFloat("blue12345"));//返回NaN
alert(parseFloat("20.34.12"))//返回20.34
alert(parseFloat(".34.12"))//返回0.34,用parseInt(".34.12")返回NaN
alert(parseFloat("-23"))//返回-23
alert(parseFloat("000012"));//返回12;
alert(parseFloat("0xA")); //返回0,不是返回十六进制值
可以使用Boolean()强制转换成布尔类型,遵循下面规则:
1、当值为非空字符串,非0数字,或是对象时,返回true
2、当值为数字0,null,NaN或空字符串时,返回false
数据类型 转换为true的值 转换为false的值
Boolean true false
String 任何非空字符串 “”空字符串
Number 任何非0数字值(包括无穷大) 0和NaN
Object 任何对象 null
Undefined —–不适用 undefined
简单测试了一些常的Boolean()返回值
alert(Boolean("a"));//返回true
alert(Boolean(2));//返回true
alert(Boolean({}));//返回true
alert(Boolean(0));//返回false
alert(Boolean("0"));//返回true
alert(Boolean(null))//返回false
alert(Boolean(""))//返回false
alert(Boolean(NaN));//返回false
alert(Boolean("true"));//返回true
alert(Boolean("false"));//返回true
alert(Boolean(undefined));//返回false
alert(Boolean("undefined"));//返回true
对象是 JavaScript 语言最主要的数据类型,三种原始类型的值——数值、字符串、布尔值——在一定条件下,也会自动转为对象,也就是原始类型的“包装对象”
在 JavaScript 中,判断一个变量的类型尝尝会用 typeof 运算符,在使用 typeof 运算符时采用引用类型存储值会出现一个问题,无论引用的是什么类型的对象,它都返回 "object"。ECMAScript 引入了另一个 Java 运算符 instanceof 来解决这个问题。instanceof 运算符与 typeof 运算符相似,用于识别正在处理的对象的类型。与 typeof 方法不同的是,instanceof 方法要求开发者明确地确认对象为某特定类型。
使用原生window.atob和btoa进行base64编码解码
本教程全面介绍 JavaScript 核心语法,从最简单的讲起,循序渐进、由浅入深,力求清晰易懂。所有章节都带有大量的代码实例,便于理解和模仿,可以用到实际项目中,即学即用。
检测这种缩放有很种方法,QQ空间都通过flash来检测浏览器是否处于缩放。这里提供javascript的方法来检测浏览器的缩放。
preventDefault它是事件对象(Event)的一个方法,作用是取消一个目标元素的默认行为。既然是说默认行为,当然是元素必须有默认行为才能被取消,如果元素本身就没有默认行为,调用当然就无效了。什么元素有默认行为呢?如链接<a>,提交按钮<input type="submit">等。当Event 对象的 cancelable为false时,表示没有默认行为,这时即使有默认行为,调用preventDefault也是不会起作用的
除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict mode)。顾名思义,这种模式使得Javascript在更严格的条件下运行。
javascript原始数据类型相互转换示例,如字符串、数字、布尔类型的相互转换
arguments是调用对象的一个属性,它与形参及局部变量是一样的,它实际上是调用了一个Arguments对象,Arguments对象与数组相似,但它又不是数组,因为它不具备数组的一些常用方法,如push,sort,shift等等。Arguments对象有两个属性:
一般情况下,判断javasceript数据类型,使用typeof 或 instanceof 就够了,但偶觉得用起来还是别别扭扭的。这里介绍一个完美的方法,我们可以轻松的判断数组,对象(这里对象暂且指{}),函数(function),布尔(Boolean),null,undefined,number,时间对象(date),正则表达式(RegExp)。
javascript提供了三个方法来计算表示小数点的位数:toFixed,toExponential,toPrecision
typeof操作符,typeof是返回“表达式”的数据类型的字符串
Javascript有五种基本的数据类型:Undefined,null,String,Number,Boolean,这五种数据类型都可以用typeof来检测
利用javascript检测浏览器的类别,网上也会有很多的代码,这里总结写了一下,主要检测主流的五款浏览器(IE,Chrome,Opera,Safari,Firefox)的类别,IE可以检测到IE6-IE9的本种版本,IE10没有检测过。
在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术
IE下给window对象定义其onresize事件,在拉伸缩小窗口时,其onresize方法将被执行多次,并且其具体执行的次数在不同的电脑有不同的值,相当诡异,Firefox等其他浏览器则无此现象
通过浏览器获取URL参数值
通过原生js获取浏览器宽高、可视区域、滚动区域等等
利用javascript来控制iframe的高度自动适应,介于javascript对不同域名权限的限制,分为两种情况
获取当前时间代码,用原生JS所写,兼容种浏览器