最开始的实现方式是,在服务端一次性获取当前页面的布局结构,当前页面的所有功能模块,同时通过循环检索某一功能模块属于哪个容器并合理放置,***获取具体功能模块的实际内容,一次性输出完成页面的显示。
创新互联长期为上千多家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为贺州企业提供专业的网站设计、网站建设,贺州网站改版等技术服务。拥有10余年丰富建站经验和众多成功案例,为您定制开发。
虽然解决了问题,但这种方式导致了单次请求返回数据的急剧增大,特别是在页面布局复杂、功能模块繁多时,尤其明显。
经过多方验证,我决定采取将布局构建和内容获取进行隔离、分批次获取内容的方式,以达到减小单次请求数据量的目的。具体步骤如下:
***步:采用常规方式,返回页面布局HTML结构,同时也json方式,返回当前页面的所有功能模块基本信息
布局HTML结构示例
1 |
同步加载的功能模块JSON
var __widgets = [ "key":"77","columnIndex":0,"sortIndex":1}, "widgetName":"statichtml","key":"76","columnIndex":1,"sortIndex":1}, "key":"82","columnIndex":1,"sortIndex":2} |
第二步:在客户端,利用js,将功能模块准确放置如对应的布局容器中
我在布局容器HTML结构中,增加了columnindex属性,在功能模块的JSON配置中对应了columnIndex属性,因此利用此属性,辅以jQuery的强大选择功能,可以非常方便的将功能模块放置入对应容器,同时JSON配置中的sortIndex属性可以确定同一容器中的先后顺序。
第三步:利用jQuery的ajax方法,分批次异步加载具体功能模块的实际内容
我们可以看到,在功能模块的JSON配置中,每一个功能模块都具有:widgetName 和 key 2个属性,widgetName属性可以确定当前功能模块的实际类型,如上例中的"statichtml"表示静态HTML文本模块,而key属性,则对应于当前模块在系统业务逻辑中所对应的唯一关键值,这个关键值需要配合功能模块的具体类型进行综合应用,以实现从数据库或XML配置文件获取内容的目的。
在异步获取功能模块的实际内容环节,我采取了分批次加载的方式,如果同时发出内容获取的ajax连接超过10个,那么后续的请求进入等待队列,等待前面的10个请求。当前10个请求返回一个时,则立即从等待队列中提出一个进行连接。这样,始终以比较平缓的数据请求量连接服务器,而页面内容也始终以比较缓和的方式呈现。
这种方式还值得完善的地方就是,***能够灵活设定,哪个功能模块的加载具有高优先级就更好了。呵呵呵,慢慢再完善了。
当前题目:JSON隔离网站布局和页面实际模块的内容载入
文章位置:http://www.mswzjz.cn/qtweb/news19/552369.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能