猫眼电影新版
解决方案:package.json
sass-loader版本改为
"sass-loader": "^7.3.1",
之后再运行(为了删除彻底,可以把node-modules下原版本的包手动删除)
cnpm install
相关链接
1、正在热映:https://m.maoyan.com/ajax/movieOnInfoList
2、影院:https://m.maoyan.com/ajax/filterCinemas?ci=57
参数:ci ⇒ 城市id
3、影院详情:https://m.maoyan.com/ajax/cinemaDetail?cinemaId=890
参数:cinemaId ⇒ 影院id
4、即将上映:https://m.maoyan.com/ajax/comingList?ci=10&token=&limit=10
参数:
ci ⇒ 城市id
limit ⇒ 请求几条
5、经典电影:https://m.maoyan.com/ajax/moreClassicList?sortId=1&showType=3&limit=10
6、最受欢迎:https://m.maoyan.com/ajax/moreClassicList?sortId=0&showType=3&limit=5
7、电影详情:https://m.maoyan.com/ajax/detailmovie?movieId=1203734
参数:movieId ⇒ 电影ID
8、想看
http://m.maoyan.com/ajax/mostExpected?ci=57&limit=10&offset=0&token=
跨域设置
config/index.js的proxyTable节点下新增:
//跨域配置
"/api":{
target:'https://m.maoyan.com',
changeOrigin: true,//是否跨域
pathRewrite:{
'^/api':''//重写接口
}
}
测试
<template>
<div>
<h1>axios测试</h1>
<button @click="test01">发一个get请求</button>
</div>
</template>
<script>
export default{
data(){
return {}
},
methods:{
test01:function(){
alert("test");
//https://api.coindesk.com/v1/bpi/currentprice.json
//https://m.maoyan.com/ajax/movieOnInfoList
this.$axios.get("/api/ajax/movieOnInfoList")
.then(response=>{
console.log(response.data);
})
.catch(error=>{
console.log(error);
})
}
}
}
</script>
<style>
</style>
数据解析
"movieList": [{
"id": 346210,
"haspromotionTag": false,
"img": "http://p1.meituan.net/w.h/moviemachine/a448ca6a5f4dafb88067722303ca0cfd96002.jpg", //w.h改为实际想要的图片宽高 128.180
"version": "v2d imax",
"nm": "八佰", //片名
"preShow": false,
"sc": 9.2, //观众评分
"globalReleased": true, //是否有观众评分
"wish": 518898, //想看
"star": "王千源,张译,姜武", //主演
"rt": "2020-08-21",
"showInfo": "今天79家影院放映665场", //放映情况
"showst": 3,
"wishst": 0
}
图标引用
cnpm install font-awesome
在main.js里面添加import 'font-awesome/css/font-awesome.css'
首页
<template>
<div class="container">
<!--head -->
<div class="header">
<div class="item01">
猫眼电影
</div>
<div class="item02">
<div class="left"><i class="fa fa-address-card"></i>猫眼</div>
<div class="right">
<span class="txt1">发现最新最热电影</span>
<span class="txt2">打开APP<i class="fa fa-angle-right"></i></span>
</div>
</div>
<div class="item03">
<div class="location">
<span>沈阳</span><i class="fa fa-caret-down"></i>
</div>
<div class="nav">
<div @click="activeNum=1">热映</div>
<div @click="activeNum=2">影院</div>
<div @click="activeNum=3">待映</div>
<div @click="activeNum=4">经典电影</div>
</div>
<div class="search">
<i class="fa fa-search"></i>
</div>
</div>
</div>
<!--content begin-->
<div class="content">
<!-- 第三步-->
<!-- 根据activeNum的值切换组件-->
<hot v-show="activeNum==1"></hot>
<coming v-show="activeNum==3"></coming>
<moreclassic v-show="activeNum==4"></moreclassic>
</div>
<!-- content end-->
<!--foot -->
<div class="footer">
<div class="item">
<i class="fa fa-address-card"></i>
<span>电影/影院</span>
</div>
<div class="item">
<i class="fa fa-crosshairs"></i>
<span>视频</span>
</div>
<div class="item">
<i class="fa fa-codepen"></i>
<span>小视频</span>
</div>
<div class="item">
<i class="fa fa-object-group"></i>
<span>演出</span>
</div>
<div class="item">
<i class="fa fa-paw"></i>
<span>我的</span>
</div>
</div>
</div>
</template>
<script>
//1\引入
import hot from '@/components/movie/hot'
import coming from '@/components/movie/coming'
import moreclassic from '@/components/movie/moreclassic'
export default{
data(){
return{
//1、在这里定义一下变量,用来切换组件 1-4 1-hot 2...
//2、点击导航按钮时,更换变量的值,1-4
//3、根据变量的值,决定加载哪个组件
activeNum:'3'//设置页面刚进入时加载哪个组件
}
},
//第二步
components:{hot,coming,moreclassic}
}
</script>
<style>
.nav .item{
height:25vw;
display:flex;
}
.header .item01{
width:100vw;
height:13.5vw;
background-color: #E54847;
display: flex;
justify-content: center;
align-items: center;
color:white;
font-size: 5vw;
}
.header .item02{
width:100vw;
height:16vw;
border:1px solid #E8E8E8;
background-color: #fff;
color:black;
display: flex;
}
.header .item02 .left{
flex:1;
color:#E54847;
height:16vw;
font-size:5.6vw ;
display: flex;
justify-content: center;
align-items: center;
}
.header .item02 .right{
height:16vw;
flex:2;
display: flex;
justify-content: flex-end;
align-items: center;
margin-right:5vw;
}
.header .item02 .right .txt1{
color:black;
font-size: 3.5vw;
margin:3vw;
color:#666;
font-weight: 600;
}
.header .item02 .right .txt2{
color:#C47E7E;
font-size: 4.5vw;
font-weight: 600;
}
.container{
box-sizing: border-box;
width: 100vw;
/* border:1px solid red; */
}
.header{
width:100vw;
height: 41.8vw;
background-color: gray;
position: fixed;
left:0;
top:0;
z-index:5;
}
.header .item03{
/* 采用flex布局后,DIV就不再是块级的标签 */
box-sizing: border-box;
width:100vw;
height:12.3vw;
background-color: #fff;
display: flex;
flex-direction:row ;
border-bottom: 1px solid #A9A9A9;
}
.header .item03 .location{
color:#666;
font-size:4vw;
width:20vw;
display:flex;
flex-direction: row;
align-items: center;
justify-content: center;
}
.header .item03 .nav{
width:68vw;
display: flex;
flex-direction: row;
justify-content: space-around;
align-items: center;
color:#666;
font-weight: 600;
font-size: 4vw;
}
.header .item03 .nav div:hover{
font-size: 5vw;
color:#333;
}
.header .item03 .search{
width:12vw;
color:#EF4238;
font-size:5.5vw;
display:flex;
align-items: center;
justify-content: center;
}
.footer{
width:100vw;
height: 13.6vw;
position: fixed;
right: 0;
bottom:0;
z-index:5;
background-color: #EEEEEE;
display: flex;
flex-direction: row;
justify-content: space-around;
}
.footer .item{
height: 13.6vw;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
color:#868686;
font-size: 3.8vw;
}
.footer .item:hover{
color:#F14B46;
}
/* 44.6
3 1.6
*/
.container{
background-color: #F5F5F5;
}
.content{
margin-bottom:1.6vw ;
box-sizing: border-box;
width:100vw;
height: 116vw;
background-color: #fff;
margin-top:44.8vw;
z-index:1;
}
.content .item{
box-sizing: border-box;
width:100vw;
height:29vw;
/* border:1px solid blue; */
display: flex;
border-bottom: 1px solid #A9A9A9;
}
.content .item .left{
margin-left:3vw;
width:17vw;
height:28vw;
}
.content .item .middle{
width:60vw;
height:29vw;
}
/* 14.4 7.4 */
.content .item .right{
width:20vw;
height:29vw;
display: flex;
justify-content: center;
align-items: center;
}
.content .item .right .box{
width:14.4vw;
height:7.4vw;
background-color:#F14B46;
border-radius: 45%;
color:white;
font-size:3.5vw;
display: flex;
justify-content: center;
align-items: center;
}
.content .item .middle{
text-align:left;
/* 上右下左 */
margin:3vw 0 3vw 2vw;
}
.content .item .middle .txt01{
font-weight: 800;
font-size: 4.5vw;
}
.content .item .middle .txt02{
padding-top:1vw;
color:#868686;
font-size: 3.5vw;
}
</style>
coming
<template>
<div class="com3">
<div class="cFirst">
<div>近期最受欢迎</div>
<ul>
<li>
<img src="https://p0.pipi.cn/mmdb/25bfd6870fa51b87a90faf628e57f311f592a.jpg?imageMogr2/thumbnail/2500x2500%3E" width="90px" height="120px">
<h4>名称</h4>
<span>2022年</span>
</li>
<li>
<img src="https://p0.pipi.cn/mmdb/25bfd6870fa51b87a90faf628e57f311f592a.jpg?imageMogr2/thumbnail/2500x2500%3E" width="90px" height="120px">
<h4>名称</h4>
<span>2022年</span>
</li>
<li>
<img src="https://p0.pipi.cn/mmdb/25bfd6870fa51b87a90faf628e57f311f592a.jpg?imageMogr2/thumbnail/2500x2500%3E" width="90px" height="120px">
<h4>名称</h4>
<span>2022年</span>
</li>
</ul>
</div>
<div class="blank"></div>
<div class="titleTime">5月27日 周五</div>
<!--列表部分 -->
<div class="cSecond">
<ul>
<!-- 3、影片循环这部分内容 :key 属性记着加,提升性能-->
<li class="fli" v-for="movie in comingList" :key="movie.id">
<!-- 实现点击图片或者文字都可以跳转到详细页,
跳转时需要携带电影ID
https://m.maoyan.com/ajax/detailmovie?movieId=?
-->
<router-link :to="{name:'detail',params:{id:movie.id}}">
<img :src="movie.img" width="65px" height="90px">
</router-link>
<div class="right">
<ul>
<li class="name">
{{movie.nm}}
</li>
<li class="score">
<div>{{movie.wish}}</div>人想看
</li>
<li class="star">主演:{{movie.star}}</li>
<li class="fre">{{movie.rt}}上映</li>
</ul>
<div class="rgh">想看</div>
</div>
</li>
<!-- 影片循环这部分内容结束-->
</ul>
</div>
<!-- -->
</div>
</template>
<script>
export default{
data(){
return{
//1、这里准备一个数组类型的变量,用来接收未来请求后台拿到coming里的数据
comingList:[]//数组类型
}
},
mounted() {
//2、请求猫眼服务器,调用相应的接口,拿到数据,
//把获取到的数据放到事先 准备好的容器comingList里
//https://m.maoyan.com/ajax/comingList?ci=10&token=&limit=10
this.$axios.get("/api/ajax/comingList?ci=10&token=&limit=10")
.then(res=>{
console.log(res)
this.comingList=res.data.coming;
})
}
}
</script>
<style>
.cFirst {
margin-top: 41.8vw;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: flex-start;
}
.cFirst div{
margin: 0 0 2vw 2vw;
}
.cFirst ul{
margin-left: 2vw;
display: flex;
align-items: center;
}
.cFirst ul li{
margin-left: 3vw;
font-size: 4vw;
}
.cFirst ul li span{
font-size: 3.5vw;
color: #999;
}
.blank{
width: 100%;
height: 3.2vw;
background-color: #F5F5F5;
margin: 1vw 0;
}
.titleTime{
display: flex;
justify-content: flex-start;
margin-left: 2vw;
color: #929292;
font-size: 4vw;
}
.cSecond ul{
padding: 3vw 0 0 3vw;
}
.cSecond ul .fli{
height:25vw;
display:flex;
}
.cSecond ul li .right{
margin-left:3vw;
display:flex;
justify-content: space-between;
align-items: center;
flex:3;
}
.cSecond ul li .right .rgh{
width:15vw;
height:8vw;
background-color: #FAAF00;
border-radius:4vw ;
color: #fff;
font-weight: 600;
display: flex;
justify-content: center;
align-items: center;
margin-right: 3vw;
}
.cSecond ul .fli .right ul {
height:25vw;
padding-top: 0;
display: flex;
flex-direction: column;
justify-content: center;
align-items: flex-start;
}
.cSecond ul li .right ul .name{
font-weight: 600;
font-size: 5vw;
height:5vw;
padding-left: 0;
padding-top: 0;
margin-bottom: 0.5vw;
}
.cSecond ul li .right ul .score{
margin-top: 1.5vw;
height:5vw;
font-size: 3.7vw;
padding-left: 0;
display: flex;
}
.cSecond ul li .right ul .score div{
margin-top: 0.8vw;
font-weight: 700;
color: #FAAF00;
font-size: 4vw;
}
.cSecond ul li .right ul .star{
margin: 0.3vw 0;
height:5vw;
padding-left: 0;
font-size: 3.7vw;
}
.cSecond ul li .right ul .fre{
font-size: 3.4vw;
}
</style>
app.vue
<style>
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
/* text-align: center;
color: #2c3e50;*/
/* margin-top: 60px; */
}
body{
margin:0;
}
li{
list-style: none;
}
</style>
预览页preview.vue
videourl是宣传片视频,可以做一个页进行播放
videourl: "https://vod.pipi.cn/43903a81vodtransgzp1251246104/de4b6163387702296511010073/v.f42905.mp4"
<!-- 点击播放视频-->
<router-link :to="{name:'preview',params:{videourl:movie.videourl}}">
<img :src="movie.img">
</router-link>
<template>
<div class="container-preview">
<video width="100%" height="" autoplay="true" >
<source :src="videourl" type="video/mp4"></source>
</video>
</div>
</template>
<script>
export default{
data(){
return {
videourl:this.$route.params.videourl
}
}
}
</script>
<style>
</style>