不过如果你自己需要扩展一些原生的对象的一些功能的话 就写在一个js文件里面,然后每个需要用到它的页面,都把这个js文件引入进来就可以了。
例如你需要扩展Date对象,加一个format Date.prototype.format=function(strFormat){}
把这个单独写在一个js文件里,然后在每个页面 中把这个js文件引入就可以了
<script type="text/javascript" src="/js/date.format.js"></script> 比如像这样的
请采纳。
当然可以重写,下面是简单的代码。仅供参考:
Array.prototype.sort = function(){return 1
}
sort的原始用法说明:
定义和用法
sort() 方法用于对数组的元素进行排序。
语法
arrayObject.sort(sortby)
参数描述
sortby 可选。规定排序顺序。必须是函数。
返回值
对数组的引用。请注意,数组在原数组上进行排序,不生成副本。
说明
如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。
现在sort方法,只会返回1.
// 重写toFixed方法
Number.prototype.toFixed = function (n) {
if (n >20 || n <0) {
throw new RangeError('toFixed() digits argument must be between 0 and 20')
}
const number = this
if (isNaN(number) || number >= Math.pow(10, 21)) {
return number.toString()
}
if (typeof (n) == 'undefined' || n == 0) {
return (Math.round(number)).toString()
}
let result = number.toString()
const arr = result.split('.')
// 整数的情况
if (arr.length <2) {
result += '.'
for (let i = 0i <ni += 1) {
result += '0'
}
return result
}
const integer = arr[0]
const decimal = arr[1]
if (decimal.length == n) {
return result
}
if (decimal.length <n) {
for (let i = 0i <n - decimal.lengthi += 1) {
result += '0'
}
return result
}
result = integer + '.' + decimal.substr(0, n)
const last = decimal.substr(n, 1)
// 四舍五入,转换为整数再处理,避免浮点数精度的损失 正数+1 负数-1
if (parseInt(last, 10) >= 5) {
const x = Math.pow(10, n)
result = (Math.round((parseFloat(result) * x)) + (parseFloat(result) >0 ? 1 : -1)) / x
result = result.toFixed(n)
}
return result
}