简单介绍:

说明: 内置对象就是不依赖宿主环境在程序执行之前已经存在的对象,不必显式的实例化内置对象,前面已经介绍了大部分内置对象,而Global和Math两个单体内置对象比较特殊,所以单独讲.


Global对象:

说明: Js中不属于任何其它对象的属性和方法,最终都是它的属性和方法,事实上没有全局变量和全局函数,所有的全局作用域中定义的属性和函数都是Global对象的属性如之前的isNaN(),isFinite(),parseInt(),parseFloat()实际上全都是Global对象的方法,除此之外还有一些常用的方法


1. 编码解码

说明: URI编码可以对链接进行编码,以便发送给浏览器,即采用特殊的UTF-8编码替换所有无效字符,从而让浏览器能够接受和理解


/*
 * encodeURI() - 不会对本身属于URI的特殊字符进行编码,例如冒号,正斜杠,问号和#
 */
encUriOne = encodeURI('http://xmdevops.blog.51cto.com/')
console.log(encUriOne)
// 部分解码
console.log(decodeURI(encUriOne))
/*
 * encodeURIComponent()() - 会对本身属于URI的特殊字符进行编码,例如冒号,正斜杠,问号和#
 */
encUriTwo = encodeURIComponent('http://xmdevops.blog.51cto.com/')
console.log(encUriTwo)
// 完全解码
console.log(decodeURIComponent(encUriTwo))

2.二次解析

说明: 主要担当一个字符串解析器的作用,只接受一个参数,这个参数就是Js代码字符串


// eval - 支持函数
eval('function love(){ return "love"}')
console.log(love())
// eval - 支持表达式
eval('var func = "love"')
console.log(func)
// eval - 支持代码
eval('alert("love")')

注意: eval()方法功能非常强大,但也非常危险,因此使用时要极为谨慎,特别是用户输入数据的情况下,非常有可能导致程序的安全性,比如代码注入


3. 对象属性

说明: Global对象包含一些属性:undefined, NaN, Infinity, Object, Array, Function, Boolean, String, Number

4. window

说明: Global没法直接访问,而Web浏览器可以使用window对象来实现全局访问(其实Global对象是作为window对象的一部分加一实现)


Math对象:

说明: Math保存数学公式和信息提供的一个对象,与我们在Js中直接编写计算功能相比,Math对象提供的计算功能执行起来要快的多

对象属性 说明
PI 派的值
SQRT2 2的平方根
SQRT1_2 2的平方根的倒数
对象方法
min(val1....valN) 获取一组数值中的最小值,返回最小的值
max(val2...valN) 获取一组数值中的最大值,返回最大的值
ceil(val) 获取大于ceil的最小整数
floor(val) 获取小于ceil的最大整数
round(val) 获取四舍五入后的最接近的整数
random() 获取0-1之间的随机数,但不包括0和1
abs(val) 返回val的绝对值
pow(val, power) 返回val的power次幂
sqrt(val) 返回val的平方根
/*
 * 获取最大最小值
 */
var arr = [1, 2, 3, 4, 5, 6, 7, 8]
console.log(
    Math.min.apply(Math, arr),
    Math.max.apply(Math, arr)
)
/*
 * 获取随机值(随机值 = Math.floor(Math.random()*最大值+最小值))
 */
var arr = ['red', 'green', 'blue', 'yellow', 'black', 'purple', 'brown']
function randIndex(total, start){
    return Math.floor(Math.random()*total+start)
}
var color = arr[randIndex(arr.length, 0)]
console.log(color)