深圳web前端培训
深圳千锋教育web前端,强师带你勇闯前端大门!
快速咨询原中科院计算所专家 千锋HTML5教学总监,千锋UI教学总监,千锋北科校区校长。原中科院计算所专家,曾任北京市高校师资培训中心特邀讲师,多年担任北京市属高校师资培训工作。11年的UI、WEB前端开发教育培训经验,4年HTML5开发经验,深刻理解教学研究、教学管理
原天天象上技术负责人 三年多web前端工作经验,有2年的移动端开发基础,负责过多个web端与移动端的项目开发,从事天天象上web2.0的pc项目,独立完成天天象上M站的构建与开发,精通angular,ionic,vue,bootstrap,swiper,highcharts等主流开发框架和流行插件。
原去哪儿网技术总监 10年以上Web前端开发经验,曾在运营大型门户网站、电商网站及研发电子政务平台的公司就职。有3年以上教学经验,出品《Web前端经典时尚案例》,《DOM探索之旅》,《Avalon探索之旅》等视频教程。
前端开发专家 千锋HTML5讲师,性格开朗,为人细心,做事认真,有较强的责任心,多年的前端项目开发经验。常以幽默的语言活跃课堂气氛。授课思路清晰,以贴切的案例,形象的演示一些难以理解的内容,让学员轻易掌握知识点并能深刻的理解和运用。
感谢老师为我们的辛苦付出,为我们准备资料 认真备课 认真耐心回答我们的问题
-学员1
严于律己,克忠职守,人生楷模,时代标杆
-学员2
特别可爱的老师,超级喜欢,我们的小伙伴,加油哦老师
-学员3
PC端网站布局
HTML5+CSS3基础
WebApp页面布局
Web前端开发工程师/前端页面布局与重构工程师等含有技术含量的工程师。
4-6K
jQuery经典交互特效开发
PHP+MySQL后端基础
前端工程化与模块化应用
HTML5大前端工程师/高级HTML5大前端工程师/网站开发工程师/移动前端开发工程师
6-10K
微信小程序开发
多端小程序开发
HTML5大前端工程师/移动前端App开发工程师/微信开发工程师/数据可视化开发工程师
10-15k
无须自备电脑
千锋提供高质量设备 保你流畅学习
无需苦恼住宿
千锋Web大前端在高校内部 入学即入住大学寝室
无需担心花费
大学食堂饭菜便宜 花样繁多气氛良好
一地学习,全国就业:就业体系覆盖全国,超18000家合作企业定期招聘,学员就业可随心选择。不同的城市,同样的全程面授。 千锋始终在坚持:全国各校区讲师统一管理,招聘标准一致,课程大纲全范围内定期升级更新,关心学员学习质量。
遇到很多想换行的朋友,第一句就问,这行赚钱吗?我相信一句话,没有付出,是没有回报的!前面已经说过了,咱们这行门槛是很低的,所以薪资阶段也不一样。2000初入这行.....
因为地区与机构的不同,费用也是不等的,目前市面上的费用一般在1万-1.6万左右。学费看似不低,但是毕业后的收入同样不菲。 根据部分网友在部分一线城市的亲身.....
1.企业规模:10人以下 我们先从几个人的小作坊说起,这种小作坊里面,基本上有一个人负责页面的设计,然后把页面“切”出来,然后有一个专门的人.....
目前WEB前端培训的学费大概在15000到20000元之间,具体要看你报的什么类型的班,以及培训机构的资质怎么样,当然,不同地域不同的机构,价格多多少少会有差别.....
先前学习过一些基于jQuery数据加载流的知识,觉得方法很多,但是万变不离其宗,今天就回顾下最原始的数据预加载的功能。
实现『加载更多』功能,网上有插件可用,例如比较著名的使用iscroll.js实现的上拉加载更多、下拉刷新功能。
但实际用起来却是很麻烦。由于是第三方插件,要按照对方定义的方法使用,用起来总感觉很不顺心。再加上iscroll.js本身并没有集成加载更多的功能,需要进行自行扩展。想继续使用iscroll.js实现加载更多功能的,上面给的链接可以看看。
h5项目里需要实现简单的分页功能,由于是移动端,考虑用『加载更多』会更好,而不是PC端的翻页。
基于按钮实现加载更多最简单的就是给一个加载更多的按钮,如果还有数据,点击下加载更多,继续拉几条数据;直到没有更多数据了,隐藏加载更多按钮。
这里提前准备好数据。演示数据格式:blog.json
{ "list": [ { "title": "这是title", "url": "http://www.xxx.com/x1.html", "desc": "摘要" }, { "title": "这是title2", "url": "http://www.xxx.com/x2.html", "desc": "摘要" }] }页面html:
加载更多按钮样式:loadmore.css:
@charset "utf-8"; .js-load-more{ padding:0 15px; width:120px; height:30px; background-color:#D31733; color:#fff; line-height:30px; text-align:center; border-radius:5px; margin:20px auto; border:0 none; font-size:16px; display:none;/*默认不显示,ajax调用成功后才决定显示与否*/ }加载更多的js代码:
$(function(){ /*初始化*/ var counter = 0; /*计数器*/ var pageStart = 0; /*offset*/ var pageSize = 4; /*size*/ /*首次加载*/ getData(pageStart, pageSize); /*监听加载更多*/ $(document).on('click', '.js-load-more', function(){ counter ++; pageStart = counter * pageSize; getData(pageStart, pageSize); }); });这里的代码并不多。其中getData(pageStart, pageSize)是业务逻辑代码,负责从服务端拉去数据。这里给个示例:
function getData(offset,size){ $.ajax({ type: 'GET', url: 'json/blog.json', dataType: 'json', success: function(reponse){ var data = reponse.list; var sum = reponse.list.length; var result = ''; /****业务逻辑块:实现拼接html内容并append到页面*********/ //console.log(offset , size, sum); /*如果剩下的记录数不够分页,就让分页数取剩下的记录数 * 例如分页数是5,只剩2条,则只取2条 * * 实际MySQL查询时不写这个不会有问题 */ if(sum - offset < size ){ size = sum - offset; } /*使用for循环模拟SQL里的limit(offset,size)*/ for(var i=offset; i< (offset+size); i++){ result +=''+ data[i].desc +'
'+ '还是比较简单的。
基于滚动事件实现加载更多上面我们通过按钮点击实现加载更多,整体过程还是比较简单的。这里,我提供另一种方法实现加载更多:基于于滚动(scroll)事件。
直接贴代码了:
$(function(){ /*初始化*/ var counter = 0; /*计数器*/ var pageStart = 0; /*offset*/ var pageSize = 7; /*size*/ var isEnd = false;/*结束标志*/ /*首次加载*/ getData(pageStart, pageSize); /*监听加载更多*/ $(window).scroll(function(){ if(isEnd == true){ return; } // 当滚动到最底部以上100像素时, 加载新内容 // 核心代码 if ($(document).height() - $(this).scrollTop() - $(this).height()<100){ counter ++; pageStart = counter * pageSize; getData(pageStart, pageSize); } }); });可以看出,代码变化不大,主要看核心代码里的判断条件:当滚动到最底部以上100像素时, 加载新内容。
业务逻辑getData(pageStart, pageSize)只需要把if ( (offset + size) >= sum)里面的逻辑改成:
if ( (offset + size) >= sum){ isEnd = true;//没有更多了}就行了。
当然,这里面还有要优化的地方,例如:如何防止滚动过快,服务端没来得及响应造成多次请求?
综合实例通过上面的例子,显然第二种更好,不用去点击。但是第二个方法有个问题:如果设置页面大小每次显示2条或3条(size=2),总记录是20,你会发现无法触发向下滚动加载更多的逻辑。这时候有个加载更多的点击按钮就好了。
因此,我们可以把以上两种方法合在一起:默认使用滚动事件实现加载更多,当显示数目太小不足以触发向下滚动加载更多的逻辑时,使用加载更多点击事件。
这里,我对加载更多这个行为进行简单的抽象,写了个简单的插件:loadmore.js
/* * loadmore.js * 加载更多 * * @time 2016-4-18 17:40:25 * @author 飞鸿影~ * @email jiancaigege@163.com * 可以传的参数默认有:size,scroll 可以自定义 * */;(function(w,$){ var loadmore = { /*单页加载更多 通用方法 * * @param callback 回调方法 * @param config 自定义参数 * */ get : function(callback, config){ var config = config ? config : {}; /*防止未传参数报错*/ var counter = 0; /*计数器*/ var pageStart = 0; var pageSize = config.size ? config.size : 10; /*默认通过点击加载更多*/ $(document).on('click', '.js-load-more', function(){ counter ++; pageStart = counter * pageSize; callback && callback(config, pageStart, pageSize); }); /*通过自动监听滚动事件加载更多,可选支持*/ config.isEnd = false; /*结束标志*/ config.isAjax = false; /*防止滚动过快,服务端没来得及响应造成多次请求*/ $(window).scroll(function(){ /*是否开启滚动加载*/ if(!config.scroll){ return; } /*滚动加载时如果已经没有更多的数据了、正在发生请求时,不能继续进行*/ if(config.isEnd == true || config.isAjax == true){ return; } /*当滚动到最底部以上100像素时, 加载新内容*/ if ($(document).height() - $(this).scrollTop() - $(this).height()<100){ counter ++; pageStart = counter * pageSize; callback && callback(config, pageStart, pageSize); } }); /*第一次自动加载*/ callback && callback(config, pageStart, pageSize); }, } $.loadmore = loadmore; })(window, window.jQuery || window.Zepto);如何使用呢?很简单:
$.loadmore.get(getData, { scroll: true, //默认是false,是否支持滚动加载 size:7, //默认是10 flag: 1, //自定义参数,可选,示例里没有用到});第一个参数是回调函数,即我们的业务逻辑。我把最终修改过的业务逻辑方法贴出来:
function getData(config, offset,size){ config.isAjax = true; $.ajax({ type: 'GET', url: 'json/blog.json', dataType: 'json', success: function(reponse){ config.isAjax = false; var data = reponse.list; var sum = reponse.list.length; var result = ''; /************业务逻辑块:实现拼接html内容并append到页面*****************/ //console.log(offset , size, sum); /*如果剩下的记录数不够分页,就让分页数取剩下的记录数 * 例如分页数是5,只剩2条,则只取2条 * * 实际MySQL查询时不写这个 */ if(sum - offset < size ){ size = sum - offset; } /*使用for循环模拟SQL里的limit(offset,size)*/ for(var i=offset; i< (offset+size); i++){ result +=''+ data[i].desc +'
'+ '基本上与最初写的是一样的。
总结其实还有那种滑动加载流等等功能,上面只是最原始的数据加载方法,希望能帮助到大家!
同意《隐私政策》并允许推荐给更多服务商为您提供服务!