window.scrollTo()方法的无效问题

this.$nextTick(() => {
        window.scrollTop(x, y)
});

这是使用方法但却无效!

后来发现是HTML对象的问题:

改为:

this.$nextTick(() => {
document.body.scrollTop(x, y) 

});

原因分析:

html、body、document、window的区别

 

html是一门超文本标记语言;

document对象代表整个html文档,可用来访问页面中的所有元素;

body代表document的主体子对象,除浏览器头部,页面中能够看到的内容都属于body中的内容;

window代表浏览器中打开的窗口,代表运行环境。

在javascript中:

window对象是一个虚拟的对象,浏览器在打开HTML文档时生成window对象,可以把它看作是你所使用的浏览器的窗口,其地位很高,因为它是浏览器脚本引擎中的globalobject。可以用window对象访问窗口中绘制的文档、窗口中发生的事件和影响窗口的浏览器特性。如果文档定义一组帧,则浏览器对原文档生成一个window对象,并对每个帧生成window对象。(关于globalobject,可以从javascript脚本引擎的概念中了解到。)

BOM的核心对象是window,它表示一个实例。在浏览器中,window对象有双重角色,它既是通过js访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象,它意味着在网页中定义的任何一个对象、变量和函数,都是以window作为其Global对象,因此有权访问isNaN()、isFinite()、parseInt()等方法。

*html元素对象*和*document对象*和*document元素对象*都是不同的:

document对象是一个跟当前文档相关的对象,拥有一些操作文档内容的功能,其功能上跟window对象差不多,因为window拥有一些操作浏览器窗口的功能。但是document对象地位没有window对象高,window拥有其他所有根对象的引用,包括browser、navigator、location等等。html元素对象和document元素对象是属于html文档的dom对象,可以认为就是html源代码中那些标签所化成的对象。他们跟div select什么对象没有根本区别。

posted @ 2019-09-19 16:29  源l  阅读(23151)  评论(0编辑  收藏  举报