`

页面加载时就确定函数实现

阅读更多

我们知道使用js获取浏览器的信息时经常涉及浏览器的兼容性.例如获取浏览器的滚动条

// Cross browser gets the position of scroll
com.whuang.hsj.getScroll=function(){
    return {
        top:document.documentElement.scrollTop || document.body.scrollTop,
        left:document.documentElement.scrollLeft || document.body.scrollLeft,
        height:document.documentElement.scrollHeight ||document.body.scrollHeight
    }
}

 上面的方法每次执行时都得判断,所以我进行了如下优化:

// Cross browser gets the position of scroll
com.whuang.hsj.getScroll=(function(){
	if(document.documentElement.scrollTop!=='undefined'&&document.documentElement.scrollTop!==0)
	{
		return function(){
			return {
				top:document.documentElement.scrollTop,
				left:document.documentElement.scrollLeft,
				height:document.documentElement.scrollHeight
			};
		};
	}else return function(){
		return {
			top:document.body.scrollTop,
			left:document.body.scrollLeft,
			height:document.body.scrollHeight
		};
	};
    
})();

 核心思想:在初始化时就确定函数的实现方式.

但是在使用过程中出现了问题,因为它的判断条件是:

if(document.documentElement.scrollTop!=='undefined'&&document.documentElement.scrollTop!==0)

但是在页面初始化时这个判断的依据是有问题的,不是实时的.在火狐中就有问题.

 

 

分享到:
评论

相关推荐

    vue动态加载外部依赖js代码实现

    - **异步加载**: 在需要加载较大文件或非关键路径资源时,推荐使用异步加载技术,以提高页面首屏加载速度。 - **按需加载**: 对于不常用的或只在特定条件下使用的功能,采用按需加载策略可以显著减少初始加载时间...

    JavaScript实现图片懒加载 图片懒加载是一种在页面加载时,延迟加载图片资源的技术,也就是说图片资源在需要的时候才会加载

    JavaScript实现的图片懒加载是一种高效的网页优化策略,尤其在处理大量图片或高分辨率图像的页面时,能够显著提升页面的加载速度和用户体验。这一技术基于滚动事件,只有当图片进入浏览器的视口(即用户能看到的区域...

    JQuery实战视频教程_页面加载时弹出一个对话框

    在本篇jQuery实战视频教程中,我们聚焦于一个常见的网页交互功能:页面加载时自动弹出对话框。这个功能在很多网站中都有应用,比如欢迎提示、重要信息通知或者用户确认操作等。jQuery库因其简洁易用的API,使得实现...

    js函数的延迟加载实现代码

    JavaScript函数的延迟加载是一种优化策略,它旨在提高页面性能,减少不必要的计算,并在需要时才执行特定的函数。延迟加载的实现通常涉及到条件检查、事件处理和代码复用。在这个例子中,我们有两个核心函数:`...

    js调用浏览器打印模块实现点击按钮触发自定义函数

    在探讨如何利用JavaScript调用浏览器的打印模块实现点击按钮时触发自定义函数的过程中,我们首先需要了解浏览器提供的打印API以及如何通过编程方式触发打印任务。现代浏览器通常提供了window.print()方法,该方法...

    lazyload 即时加载图片(鼠标滑动不同页面时,才加载相应图片)

    这可以通过jQuery的`.fadeIn()`等动画函数实现。 6. **优化考虑**:为了进一步优化,我们可以考虑预加载部分图片,防止用户快速滚动时出现空白。此外,对于移动设备,可以考虑使用Intersection Observer API,它是...

    vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多(步骤详解).docx

    要实现下拉刷新和上拉加载更多的功能,需要使用 Vue.js 的生命周期钩子函数,例如 created 和 mounted 函数。在这些函数中,可以使用 Axios 库来获取数据,并将数据展示在页面上。 ### 2.5 解决图片高度不一致的...

    jQuery实现图片预加载

    总结来说,jQuery实现图片预加载能显著提升网页的响应速度和用户体验。通过自定义代码或使用预加载插件,开发者可以轻松地在项目中实现这一功能。不过,需要注意的是,预加载并不适用于所有情况,对于大容量图片或...

    上拉 加载 刷新 页面

    实现上拉加载的关键在于监听用户的滚动事件,当页面内容接近底部时触发新的数据请求。 1. 监听滚动事件:使用JavaScript或jQuery,我们可以监听`scroll`事件来确定用户是否接近页面底部。例如,用jQuery可以这样写...

    sweetalert加载弹窗完成自动关闭

    在"SweetAlert加载弹窗完成自动关闭"这个主题中,我们将深入探讨如何使用SweetAlert创建一个加载弹窗,并在加载完成时自动关闭。 首先,让我们了解SweetAlert的基本用法。在网页中引入`sweetalert2.min.js`库后,你...

    html5触屏手机端上下拉滑动加载更多数据

    当用户将页面滚动到接近底部时,触发一个函数,这个函数通过Ajax或Fetch向服务器发送请求,获取新的数据。在请求成功后,将新数据插入到容器的末尾,同时更新页面状态,如显示“加载中”的提示,防止用户在数据加载...

    js异步加载代码

    JavaScript 异步加载是优化网页性能的关键技术,它能让页面在不等待脚本执行的情况下继续渲染,从而提高用户体验。在现代网页开发中,由于 JavaScript 文件的体积越来越大,同步加载(即默认方式)会阻塞浏览器解析...

    原生JS瀑布流布局,无限加载

    1. 滚动检测:监听滚动事件,当用户接近页面底部时,触发加载更多数据的函数。 2. 加载更多数据:向服务器发送请求,获取更多数据。可以使用分页机制,每次请求一定数量的数据。 3. 插入新元素:将新加载的数据插入...

    WebView加载本地Html文件并实现点击效果

    在Android开发中,WebView是一个非常重要的组件,它允许我们在应用程序中内嵌网页内容,实现与网页的交互。本文将详细讲解如何使用WebView加载本地HTML文件,并实现点击按钮后弹出对话框的效果。 首先,我们需要在...

    手机端无限滚动加载

    2. **判断条件**:当用户滚动到距页面底部一定距离时,触发加载更多内容的函数。这个距离可以通过计算窗口高度、文档总高度和滚动位置来确定。 3. **API调用**:通常,新的内容是通过服务器提供的API获取的。使用`...

    jQuery类似微博信息更新鼠标滚动页面无限加载更多内容

    "jQuery类似微博信息更新鼠标滚动页面无限加载更多内容"这个主题,就是关于如何利用jQuery实现一个动态加载机制,即“滚动加载”或“懒加载”,让用户在浏览时无需翻页,只需滚动页面就能自动加载更多内容。...

    Justlazyjs是一个响应式图像加载工具可以实现延迟加载

    Justlazy.js 是一款高效、轻量级的JavaScript库,专门设计用于实现响应式图像加载,尤其是在现代网页设计中,这种特性对于提升用户体验和优化页面性能至关重要。延迟加载,也称为懒加载,是一种策略,它允许网页只在...

    使用Vue实现调用接口加载页面初始数据

    以下就详细介绍使用Vue实现调用接口加载页面初始数据所涉及的关键知识点。 首先,Vue实例是Vue.js中构建整个应用程序的基础,任何应用都需要通过new Vue()创建一个根实例。在上述代码中,let vm = new Vue({})就是...

    js lazyLoad 图片懒加载demo

    在网页加载时,非首屏的图片不会立即下载,而是等待用户滚动到图片所在位置时才开始加载。这种方式可以有效减少初始加载时间,特别是对于包含大量图片的页面,可以极大提升页面的加载速度。 关于"js lazyload image...

Global site tag (gtag.js) - Google Analytics