美文网首页Vue2.0开发企业级移动音乐APP
三、推荐页面开发-轮播图

三、推荐页面开发-轮播图

作者: 六个周 | 来源:发表于2019-01-10 23:35 被阅读63次

由于代码的开发加上章节的总结会对专注代码带来巨大的精力与时间投出,于是不在逐行代码进行解析,从本节开始我会直接把在项目开发过程中遇到的知识点进行总结,并直接上代码地址。

本章节实现源码:
https://github.com/liugezhou/liugezhou_music/tree/chapter3

效果实现:

vue-music.png

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
以上列出的为主要修改文件,其它省略。

本节完。

相关文章

  • 三、推荐页面开发-轮播图

    由于代码的开发加上章节的总结会对专注代码带来巨大的精力与时间投出,于是不在逐行代码进行解析,从本节开始我会直接把在...

  • iOS轮播图的封装库(一行代码解决应用中的scrollView轮

    作为一个iOS开发者,我们经常需要用到轮播图,比如:我们首页顶部的广告轮播,商品详情页面的商品图片轮播等,如果我们...

  • 2018-03-09

    UICollectionView在一个页面中,既有轮播图 又有UICollectionView时,需要点击轮播图 ...

  • music-app项目总结

    1.关于项目依赖配置 2.问题总结 3.$refs坑:轮播图刷新出错问题 问题描述:推荐页面轮播图一刷新,变成竖直...

  • 原生JS轮播图

    :轮播图 1:页面 2:CSS 3:Js

  • 2018-10-24

    简单的轮播图 html代码 轮播图 动漫推荐 来自风平浪...

  • h5页面中有定时器的时候,轮播图不滚动

    (1)轮播图 react-slick 的使用,但是页面中有其他定时器的时候,轮播图不滚动npm install ...

  • BannerView-无限轮播图控件

    轮播图控件,封装ViewPager,支持无限循环轮播,支持三种常用页面特效,支持设置指示器,支持自动切换手动滑动和...

  • 手把手教你用JS写一个图片轮播效果

    1、前言 写页面的时候,有些地方经常会用到一些轮播图,比如主页Banner的轮播,或者在页面最下面的小图片轮播,这...

  • 依赖

    //滑动框 (轮播图,引导页面) implementation'com.youth.bann...

网友评论

    本文标题:三、推荐页面开发-轮播图

    本文链接:https://www.haomeiwen.com/subject/xthirqtx.html