通常使用Yahoo! Map的时候,是采用其网站提供的方法:
js 代码
- <script type="</span">"text/javascript"
- src="http://api.maps.yahoo.com/ajaxymap?v=3.7&appid=YahooDemo">
- </script>
这种做法的缺点是在页面加载的时候就会去加载Yahoo! Map的javascript文件,这会造成页面加载速度变慢。因为它的javascript是采用document.write的方法来输出其需要包含的其他javascript文件的,因为不能直接采用动态创建script元素的方式来延迟加载。
我的做法是把Yahoo! Map的加载的javascript文件的内容提取出来,把其中的document.write改成动态的构建script元素的方式来加载。
xml 代码
- <html>
- <head>
- <style type="text/css">
- #map{
- height: 75%;
- width: 100%;
- }
- </style>
- <script type="text/javascript">
- var YAHOO=window.YAHOO||{};
- YAHOO.namespace=function(_1){ if(!_1||!_1.length){ return null; }
- var _2=_1.split(".");
- var _3=YAHOO;
- for(var i=(_2[0]=="YAHOO")?1:0;i<_2.length;++i){ _3[_2[i]]=_3[_2[i]]||{}; _3_3=_3[_2[i]]; } return _3; };
- YAHOO.namespace("util");
- YAHOO.namespace("widget");
- YAHOO.namespace("example");
- var YMAPPID = "YahooDemo";
- </script>
- </head>
- <body id="body">
- <div id="map"></div>
-
- <script type="text/javascript">
- function loadYMap() {
- loadByScript('http://us.js2.yimg.com/us.js.yimg.com/lib/common/utils/2/dom_2.0.1-b2.js');
- loadByScript('http://us.js2.yimg.com/us.js.yimg.com/lib/common/utils/2/event_2.0.0-b2.js');
- loadByScript('http://us.js2.yimg.com/us.js.yimg.com/lib/common/utils/2/dragdrop_2.0.1-b4.js');
- loadByScript('http://us.js2.yimg.com/us.js.yimg.com/lib/common/utils/2/animation_2.0.1-b2.js');
- loadByScript('http://us.js2.yimg.com/us.js.yimg.com/lib/map/js/api/ymapapi_3_7_1_11.js');
-
- displayMap();
- }
-
- function displayMap() {
- if (window.YMap) {
- // Create a map object
- var map = new YMap(document.getElementById('map'));
-
- // Add map type control
- map.addTypeControl();
-
- // Set map type to either of: YAHOO_MAP_SAT, YAHOO_MAP_HYB, YAHOO_MAP_REG
- map.setMapType(YAHOO_MAP_SAT);
-
- // Display the map centered on a geocoded location
- map.drawZoomAndCenter("San Francisco", 3);
- }
- else {
- setTimeout(displayMap, 200);
- }
- }
-
- function loadByScript(url) {
- var script = document.createElement("script");
- script.setAttribute("type", "text/javascript");
- script.src = url;
- var body = document.getElementById("body");
- body.appendChild(script);
- }
- </script>
- <p>
- <input type="button" value="Load..." onclick="loadYMap();"></input>
- </p>
- </body>
- </html>
上面的页面只有在点击了Load...按钮的时候才会去加载Yahoo! Map的javascript文件,并把地图显示出来。
分享到:
相关推荐
此外,对于视口内的图片,可以通过预加载技术提前加载,避免用户滚动到该位置时出现明显的加载延迟。 通过合理应用图片延迟加载技术,可以有效改善网页性能,尤其是对于内容丰富的网站和移动设备,这种优化显得尤为...
Lazyload是通过延迟加载来实现按需加载,达到节省资源,加快浏览速度的目的。 网上也有不少类似的效果,这个Lazyload主要特点是: 支持使用window(窗口)或元素作为容器对象; 对静态(位置大小不变)元素做了大量...
网页内容延迟加载(LazyLoad)是一种优化网页性能的技术,它主要应用于图片、视频或大量文本内容的加载。这种技术的核心思想是,只加载用户当前视口内的内容,当用户滚动页面,即将进入视口的内容才会被加载。这样...
在实际开发中,为了提高性能和减少内存消耗,MyBatis提供了延迟加载(Lazy Loading)功能。延迟加载允许我们在真正需要数据时才去加载关联的对象,而不是在查询主对象时一次性加载所有关联数据。 标题中的“mybatis...
这个类主要用于实现延迟加载(Lazy Loading),它允许我们推迟对象的初始化,直到真正需要使用该对象时才会执行初始化过程。这种方式在处理大数据集合或者复杂对象时尤其有用,因为它可以避免在不必要时消耗宝贵的...
图片延迟加载(Lazy Load)是一种优化网页性能的技术,它通过只加载用户当前视口内的图片,而将其他未显示的图片推迟到用户滚动到相应位置时再加载,从而减少了页面初次加载的时间,提升了用户体验。在网页设计中,...
2. **预加载策略**:对于重要图片,比如页面顶部的大图,可以考虑在页面加载时就进行预加载,防止用户在滚动时出现明显的加载延迟。 3. **动画效果**:加载图片时,可以添加过渡效果,比如淡入、渐显,提升用户体验...
1. **什么是页面延迟加载(Lazy Loading)?** 页面延迟加载,也称为懒加载,是一种优化策略,主要用于图像、视频和脚本等网页元素。它不一次性加载所有内容,而是仅在用户滚动到可视区域时才加载相应的元素。这样...
在Java的持久化框架Hibernate中,懒加载(Lazy Loading)是一种重要的优化策略,它的核心思想是“延迟加载”或“按需加载”。默认情况下,当一个实体被加载时,并不会立即加载其关联的对象或集合,而是在真正需要...
《延迟加载(LazyLoad):优化网页性能的关键技术》 在当今互联网时代,大型网站面临着一个挑战:如何在满足用户体验的同时,尽可能减少服务器资源的消耗。延迟加载(LazyLoad),也称为按需加载,就是为解决这一...
这种技术通常被称为“懒加载”(Lazy Loading)。在标题“jquery Loading图片延迟加载特效.zip”中,我们可以理解这是一款基于jQuery实现的图片延迟加载插件或库,它包含了一个用于展示滚动页面时图片逐步加载的特效...
HTML延迟加载图片,也称为懒加载(Lazy Load),是一种优化网页性能的技术,它允许网页只在需要时才加载图片,而不是一次性加载所有内容。这种技术对于拥有大量图片的页面尤其有益,因为它可以显著减少页面的初始...
延迟加载,也称为懒加载(Lazy Loading),是指在需要时才加载资源的技术。这种技术主要用于减少初始页面加载的时间,特别是对于那些大型网站和含有大量图片的页面。延迟加载的主要思想是,只有当用户滚动到特定元素...
jQuery.lazyload则是一个基于jQuery的插件,专门用于实现图片延迟加载。 **一、jQuery.lazyload的基本原理** jQuery.lazyload的工作原理是监听滚动事件,当用户滚动页面,即将或已经看到图片时,才开始加载图片。...
JQuery 图片延迟加载 lazyload
**延迟加载(LazyLoad)技术概述** 延迟加载是一种优化网页性能的策略,它允许我们只在需要时才加载资源,如图片、JavaScript或CSS。这种技术显著减少了初始页面加载时间,提高了用户体验,尤其是在移动设备上,...
在网页设计中,为了提高页面加载速度和优化用户体验,一种常见的技术是图片延迟加载,也称为懒加载(Lazy Load)。JavaScript 是实现这一功能的主要工具,它允许我们在用户滚动到图片时才加载图片,而不是一次性加载...
"延迟加载"(Lazy Loading)技术就是一种有效的HTML优化策略,它旨在减少页面初次加载时的数据量,提高页面的响应速度,进而改善用户的浏览体验。延迟加载的核心思想是只在用户需要时才加载图像或其他资源,而不是一...
延迟加载(Lazy Loading)是指仅加载用户可视区域内的资源,当用户滚动页面时,浏览器才会加载即将进入视口的图片或其它资源。这种技术可以显著提高网页的加载速度,特别是对于包含大量图片的页面,可以避免一次性...
本篇将深入探讨 Mybatis 的两个重要特性:延迟加载(Lazy Loading)和缓存机制。 ### 延迟加载(Lazy Loading) 延迟加载是一种优化策略,它的核心思想是不立即加载所有数据,而是在实际需要时才进行加载。在 ...