标准规范
HTML5规范文档中指出:如果一个元素符合下面两条规则中的任一条,则window对象中必须要有与之对应的一个属性,属性值就是这个对象.
- 如果一个元素拥有ID属性,那么ID属性的属性值就会成为window对象的属性名.
- 如果一个元素拥有name属性,那么name属性的属性值就会成为window对象的属性名.但这个元素的标签名必须是: a, applet, area, embed, form, frame, frameset, iframe, img, object,其中的一个.
让我们看一个例子.假定存在一个页面,该页面包含了一个ID属性为“foo”的div元素:
复制代码 代码如下:
<div id="foo"></div>
这样一来,上面的的div元素就可以通过window.foo(和其他的window属性一样),或者全局变量foo来访问到.比如,在Chrome控制台中,你可以这样做:
复制代码 代码如下:
> "foo" in window
true
> foo
<div id="foo"></div>
Firefox
火狐(14)的工作方式略有不同.
复制代码 代码如下:
> "foo" in window
false
> typeof foo // 这个全局变量到底有木有?
object
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.
> foo
[object HTMLDivElement]
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.> "foo" in window true
复制代码 代码如下:
> "foo" in window
false
> typeof foo // 这个全局变量到底有木有?
object
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.
> foo
[object HTMLDivElement]
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.> "foo" in window true
这到底是怎么一回事?初始化时,window并没有属性foo.但在第一次访问这个属性的时候(通过window.foo属性直接访问或者通过全局变量foo来访问都可以),它会被自动建立.
译者注:我在Firefox14,15,18中都没有发现警告,不过在Firefox12试验时,的确有警告.
[注意:例子中的代码只能在网页中通过script标签运行才能见效,不能通过终端运行.这是因为终端在处理全局对象时,使用了不同的方式.]
译者注:我在Firebug中尝试例子中的代码,并没发现有什么差别.
一旦你尝试读取foo的值,虽然会正常返回那个div元素,但同时错误控制台会有警告,告诉你不应该那么做.很显然,这样的警告是正确的:在终端调试的时候,你可以使用这个特性,但在实际的代码中,不应该使用.
Cody Lindley写了一个jsPerf测试来比较通过全局变量访问foo和通过window.foo来访问foo的性能差别.有趣的是,只有在Firefox中访问window.foo更快点.
相关推荐:
ChatGPT维护页面-背后的技术与用户体验,ai领域ppt
求一个AI软件,彻底改变你的工作与生活!
文章AI扩写:突破创作瓶颈,提升写作效率的秘密武器
ChatGPT怎么打不开了?解决办法,轻松恢复畅通无阻!,ai订酒店ai对话
seo适合看什么书,自学seo书籍推荐 ,ai少女 刻晴
为什么行业都要做seo,为什么要做seo ,ai明信片
seo简报什么意思,seo工作汇报 ,万花筒 ai
互联网快排:助力企业网站流量爆发的秘密武器,西安网站建设找资源公司
在线AI文章:为您打造全新内容创作体验
好用的AI智能工具,让生活与工作更高效!
seo都有什么意思,seo 啥意思 ,ai园林
SEO优化工具优势:提升网站排名,带来流量和转化的秘密武器,ai圆形造字
chatai写作免费一键生成,轻松解决写作难题!,陈逗逗ai换脸在线看
seo需要什么能力,seo需要哪些技术 ,ai长条弯曲
seo适合什么行业,seo适合的行业 ,在ai如何矢量化
ChatGPT中显示已进行一处编辑,但看不到内容?你需要了解的隐藏问题!,ai敲
ChatGPT:人工智能对话新时代的领航者,ai音响华为还是小米好
什么是seo公司口碑,seo品牌 ,ai大模型训练是什么意思
ChatGPT:OpenAI的创新之作-一款颠覆传统的语言模型,ai球衣号
ChatGPTWindows版本下载:让AI助力您的工作和生活,ai yamama
seo需要干什么,seo需要具备什么知识 ,ai梦境档案世岛大宅
SEO定价策略:如何根据企业需求定制最佳价格方案,教育培训抖音营销推广
seo诊断什么意思,seo诊断a5 ,约瑟夫ai
SEO有话:如何用精准优化助力企业在线增长,食品微信营销推广
优化投入,让企业更具竞争力,怎样推广营销方案
什么是seo模型,seo模块总结 ,ai技术授课
AI自动生成:开启智能时代的无限可能,ai熊熊图片
SEO指:如何通过精准优化提高网站流量和转化率,无锡论坛营销推广要多久
软件AI:颠覆未来的智能革命
SEM+SEO:助力企业数字化营销的双剑合璧之道,ai头像丑
AI人工智能:开发与应用的必备软件推荐
企业SEO:如何通过搜索引擎优化提升企业网络竞争力,安阳网站优化布局设计
文章AI思维导图自动生成助力创作的智慧之源
seo要懂些什么软件,seo常用软件 ,ai写作网站网址大全
ChatGPT无服务:如何突破限制,未来人工智能的新可能,ai绘制装饰画
SEO小白必看!从零起步SEO的秘诀,轻松提升网站排名,南京网站运营优化平台
SEO外包:提升网站排名与品牌曝光的最佳选择,大创建设网站
AI人工智能文章生成平台,释放创作无限可能
《权重参谋:让您的网站轻松登顶搜索引擎的秘密武器》,设计微信社群私域营销推广简案
ChatGPT免费版的限制:你需要了解的5大制约因素,Ai分解模型
ChatGPT显示无法加载网站是怎么回事?解决方法!,glow将军ai
高效创作之路:文章AI生成器的力量
如何选择适合你的AI工具?全面解析AI工具哪个好用
SEO关键词是什么意思?全面解析SEO关键字的核心作用,华为ai音箱 百度ai音箱
怎样用AI写文章?快速高效创作新技能!
GPT在什么时候被人熟知的?从技术突破到广泛应用的背后故事,ai商业新思维ai课程
SEO在广告领域的深度解析:如何利用SEO提升广告效果,网文写作ai工具
为什么说seo重要,为什么说seo重要一点 ,中通智能ai是什么意思
用AI写文章会不会查重率高?破解写作困扰的真相
SEO包月服务:助力企业提升网站排名与流量的长期利器,网站建设流程 报读文库