由于代码的开发加上章节的总结会对专注代码带来巨大的精力与时间投出,于是不在逐行代码进行解析,从本节开始我会直接把在项目开发过程中遇到的知识点进行总结,并直接上代码地址。
本章节实现源码:
https://github.com/liugezhou/liugezhou_music/tree/chapter3
效果实现:

jsonp原理介绍
我们这里轮播图是抓取扣扣服务器上的数据,于是代码开始前先了解一下JSONP。
老师大概是这么讲解的:
jsonp就是为了解决前端的跨域问题而进行的一项设计,jsonp之所以能实现跨域,是因为它不是ajax请求,它动态创建了script标签,script标签是不受同源策略限制的,将script的src指向正式的服务器地址。
查找资料:
目前为止(2012年)最被推崇或者说首选的方案还是用JSON来传数据,靠JSONP来跨域。
JSON是一种数据交换格式,而JSONP是一种依靠开发人员的聪明才智创造出的一种非官方跨域数据交互协议。
JSONP是怎么产生的:
1、一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题,甭管你是静态页面、动态网页、web服务、WCF,只要是跨域请求,一律不准;
2、不过我们又发现,Web页面上调用js文件时则不受是否跨域的影响(不仅如此,我们还发现凡是拥有"src"这个属性的标签都拥有跨域的能力,比如<script>、<img>、<iframe>);
3、于是可以判断,当前阶段如果想通过纯web端(ActiveX控件、服务端代理、属于未来的HTML5之Websocket等方式不算)跨域访问数据就只有一种可能,那就是在远程服务器上设法把数据装进js格式的文件里,供客户端调用和进一步处理;
4、恰巧我们已经知道有一种叫做JSON的纯字符数据格式可以简洁的描述复杂数据,更妙的是JSON还被js原生支持,所以在客户端几乎可以随心所欲的处理这种格式的数据;
5、这样子解决方案就呼之欲出了,web客户端通过与调用脚本一模一样的方式,来调用跨域服务器上动态生成的js格式文件(一般以JSON为后缀),显而易见,服务器之所以要动态生成JSON文件,目的就在于把客户端需要的数据装入进去。
6、客户端在对JSON文件调用成功之后,也就获得了自己所需的数据,剩下的就是按照自己需求进行处理和展现了,这种获取远程数据的方式看起来非常像AJAX,但其实并不一样。
7、为了便于客户端使用数据,逐渐形成了一种非正式传输协议,人们把它称作JSONP,该协议的一个要点就是允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。
关于jsonp的学习,可以移除至:https://github.com/webmodules/jsonp
代码介绍:
1.jsonp的安装----pacakage.json/dependencies
2.jsonp的封装:
https://github.com/liugezhou/liugezhou_music/blob/chapter3/src/common/js/jsonp.js
3.轮播图数据的抓取:
1、抓取数据用到的公共数据参数的封装:
https://github.com/liugezhou/liugezhou_music/blob/chapter3/src/api/config.js
2、轮播图数据的封装:
https://github.com/liugezhou/liugezhou_music/blob/chapter3/src/api/recommend.js
3、推荐页面轮播图数据的引入与轮播图组件的开发:
数据引入:
https://github.com/liugezhou/liugezhou_music/blob/chapter3/src/components/recommend/recommend.vue
轮播图组件:
https://github.com/liugezhou/liugezhou_music/blob/chapter3/src/base/slider/slider.vue
以上列出的为主要修改文件,其它省略。
本节完。
网友评论