javascript中download关键字的方法名调用问题

今天在写代码的时候发现一个很奇怪的现象,代码如下:

这个demo在ie8下正常,但是在chrome和ff都有问题

<html>

<head>

<script type="text/javascript">
function download(){
alert("123");
}
</script>

</head>
<body>

<a href="javascript:void(0);" onclick="javascript:download();">Test</a>

</body>
</html>


查阅了一下资料发现了答案:
http://stackoverflow.com/questions/7852237/cant-use-download-as-a-function-name-in-javascript


[b]download是html5中新增的一个属性,所以在现代浏览器上都会解析成属性。这个属性是一个事件定义,并且优先于js中的方法(window.download)。所以点调用download()方法的时候,在现代浏览器中会触发element.download();而不是window.download。所以在ie8这样的老古董下面没有element.download()会直接调用window.download();
[/b]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript,let关键字是ES6新增的一个变量声明关键字,与var关键字相比具有一些特点和区别。 首先,let关键字声明的变量具有块级作用域。意味着在被声明的块级作用域内(如函数、循环、条件语句等),let关键字声明的变量仅在该块内部有效,超出该范围就无法访问。这与var声明的变量不同,var声明的变量具有函数作用域。 其次,let声明的变量不存在变量提升。在使用var声明变量时,可以在之后的代码进行访问,即使在声明之前也不会报错。但是使用let声明的变量必须在声明之后才能访问,否则会抛出“暂时性死区(Temporal Dead Zone)”错误。这样就能杜绝在变量定义之前就使用变量的错误行为,提高代码的健壮性和可读性。 另外,使用let关键字可以避免变量的重复声明。在同一个作用域(包括嵌套作用域),使用let声明同变量会报错,而使用var声明则会覆盖之前的同变量。这样可以减少潜在的变量冲突问题,提高代码的可维护性。 最后,let关键字声明的变量不会将变量添加到全局对象,而var声明的变量会成为全局对象的属性。这意味着使用let声明的变量在全局环境不可访问,从而减少了全局命空间的污染。 总之,let关键字JavaScript具有块级作用域、不存在变量提升、不允许重复声明以及不污染全局环境等特点,使得变量的作用范围更加清晰、规范,提高了代码的可读性和健壮性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值