JavaScript笔记本

本文探讨了JavaScript中全局变量的定义方式及其与window对象属性的区别,并介绍了如何使用window对象的人机交互接口,同时提供了判断对象属性存在性的正确方法及字符串转文件下载的示例。

【知识的学习需要点滴积累,我想把这篇文章作为自己的一个错题本类似的东西,持续更新。。。。】

 

1、定义全局变量与在window对象上直接定义属性还是有一点不同:全局变量不能通过delete运算符删除,而直接在window对象上定义的属性可以被删除。因为使用var声明全局变量,window会为这个属性定义一个名为“configurable”的特性 ,这个特性的值被设置为false,这样该属性就不可以通过delete运算符删除。

var a ="a";
window.b = "window.b";
c = "c";

console.log(delete a);          //false
console.log(delete window.b);   //true
console.log(delete c);        //true

console.log(a);        //a
console.log(window.b);   //undefined
console.log(c);    //Uncaught ReferenceError: c is not defined at <anonymous>:11:13
console.log(window.c);  //undefined

注意:直接访问JavaScript变量会如同上面倒数第二行会抛出异常,但是通过window对象进行访问,可以判断未声明变量是否存在。

2、window对象定义了3个人机交互接口

alert("这里放置提示信息" + 变量);
confirm("这里放置提示信息");     
//包含两个按钮——确定和取消  点击“确定”返回true   点击“取消”返回false
prompt("提示信息"); 
//包含输入框,用于接收用户输入信息并返回

这里可以通过window.alert = function(){}重写alert()方法。

 

 

3. 判断对象某个key是否存在不能用typeof,应该使用hasOwnProperty

X      typeof( obj.name ) === 'undefined'

√      obj.hasOwnProperty( 'name' )

 

 

4. 将字符串封装成文件下载,注意只能下载浏览器不支持打开的文件格式

var str = "Hello world!";
var url= 'data:text/plain;charset=utf-8,\ufeff' + encodeURIComponent(str);
var link = document.createElement("a");
link.href = url;
link.download = 'filename.txt';
link.click();
link = null; 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值