微信小程序模仿豆瓣评分使用网络请求数据页面交互传值

首页效果图

 

微信小程序模仿豆瓣评分使用网络请求数据页面交互传值_第1张图片

详情页效果图

微信小程序模仿豆瓣评分使用网络请求数据页面交互传值_第2张图片

 

componment组件:

Taps.wxml


  
  
    
  

Taps.wxss

.searchbar{
  background:#41be57;
  padding: 20rpx 20rpx;
}
.search-navigator{
  width: 100%;
  height: 60rpx;
  background-color: #fff;
  border-radius: 6rpx;
  background-image: url("");
  background-size:8%;
  background-repeat:no-repeat;
  background-position: center; 
}
.search-input-group{
  width: 100%;
  height: 60rpx;
  background-color: #fff;
  padding: 6rpx 20rpx;
  box-sizing: border-box;

}
.search-input{
  height: 40rpx;
  font-size: 12px;
}
.xiangshang{
  margin-top: -10rpx;
}

.star{
  height: 60rpx;
  width: 60rpx;
  display: inline-block;
}
.stars-group{
  text-align: center;
   font-size: 60rpx;
  
}

Taps.json

{
  "component": true,
  "usingComponents": {}
}

Taps.js

Component({
  /**
   * 组件的属性列表
   */
  properties: {
    isnavigator:{
      type:Boolean,
      value:false

    }
  },

  /**
   * 组件的初始数据
   */
  data: {
   rate:4,
   light:'',
   gray:'',
   half:'',
   ratenum:''

  },
  
  /**
   * 组件的方法列表
   */
  methods: {
    onInputEvent: function(event){
      var value = event.detail.value;
      var detail = {"value": value};
      var options = {};
      this.triggerEvent("searchinput",detail,options);

    }

  }
})

评分星星组件

stars.wxml



 
 
 
 {{ratetext}}

stars.wxss

/* component/stars/stars.wxss */
.rate-group{
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 80rpx;
  color: #ccc;
}
.rate-group image{
  height: 30rpx;
  width: 30rpx;
}

stars.js

// component/stars/stars.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    rate:{
      type:Number,
      value:0,
      observer(newVal,oldVal,changePath){
        //属性被改变时执行的函数(可选)也可以卸载methods断种定义的方法名字符串,如'_propertyChange'
        //通常newVal代表新数据,oldVal就是旧数据
        this.updateRate();
      }
    },
    fontsize:{
      type:Number,
      value:20
    },
    fontcolor:{
      type:String,
      value:"#ccc"
    },
    istext:{
      type:Boolean,
      value:true
    }

  },

  /**
   * 组件的初始数据
   */
  data: {
    lights:[1, 2],
    halfs:[1, 2],
    grays:[1, 2], 
    ratetext:"7.3",
    istext:true

  },



 lifetimes:{
   attached:function(){
     this.updateRate();

   }

  },
  /**
   * 组件的方法列表
   */
  
  methods: {
    updateRate:function(){
      var that=this;
      var rate = that.properties.rate; //评分
      var intRate = parseInt(rate);    //将输入的评分取整
      var light = parseInt(intRate/2);  //计算亮着的星星,评分除以二后取整
      var half = intRate%2;   //半星的计算就是取整后的评分取余
      var gray = 5 - light - half; //灰色星星的计算
      var lights = [];
      var halfs = [];
      var grays = [];

      for(var i=1;i<=light;i++){
        lights.push(i)
      }

      for (var i = 1; i <= half; i++) {
        halfs.push(i)
      }

      for (var i = 1; i <= gray; i++) {
        grays.push(i)
      }
      var ratetext = rate && rate > 0 ? rate.toFixed(1):"未评分"
      this.setData({
        lights:lights,
        grays:grays,
        halfs:halfs,
        ratetext:ratetext

      })


  }
  }
})

更多按钮点击跳转的列表页

indexmodle.wxml



 
   {{title}}
   更多
   
  
 
  
 

indexmodle.wxss

/* component/indexmodule/indexmodule.wxss */
.module-group{
  padding: 40rpx;
  background: #fff;
}
.module-top{
  font-size: 36rpx;
  display: flex;
  justify-content: space-between;

}
.module-title{
  color:#494949;
}
.module-more{
  color: #41be57;
}
.module-scroll-view{
  margin-top: 40rpx;
  width: 100%;
  height: 100%;
  white-space:nowrap;

}

indexmodle.json

{
  "component": true,
  "usingComponents": {
    "iterview": "../../component/Iterview/Iterview"
}
}

indexmodle.js

// component/indexmodule/indexmodule.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    title:{
      type:String,
      value:""
    },
    moreurl:{
      type:String,
      value:''
    },
    items:{
      type:Array,
      value:[]
    },
    type: {
      type: String,
      value: ''
    }
    

  },

更多按钮点击后单个影视组件(包含影视图片,影视名,评分)

Iterview.wxml




 
  
    
   
  {{item.title}}
  
 

Iterview.wxss

/* component/Iterview/Iterview.wxss */
.item-navigator{
  width: 208rpx;
  margin-right: 20rpx;
  display: inline-block;

}
.item-navigator .item-group{
  width: 100%;
 
}
.item-group .thumb-group{
 
  width: 100%;
  height: 300rpx;

}
.thumb-group .thumbnail{
  width: 100%;
  height: 100%
}
.item-group .item-title{
  font-size: 28rpx;
  text-align: center;
  margin-top: 20rpx;
  text-overflow: ellipsis;
  overflow: hidden;
  margin-bottom: 15rpx;
}

Iterview.json

{
  "component": true,
  "usingComponents": {
    "stars": "../../component/stars/stars"
  }
}

Iterview.js

// component/Iterview/Iterview.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    film: {
      type: Array,
      value: {
        name: '',
        src: ''
      }
    },
     item: {
      type: Object,
      value: {}
    },
    itemurl: {
      type: String,
      value: " "

    }

  },
  

详情页组件

onecomment.wxml



  
    
  
  
     
      {{item.user.name}}
      
     
     {{item.create_time}}
     {{item.comment}}
  

onecomment.wxss

/* component/onecomment/onecomment.wxss */
.comment-group {
  display: flex;
  justify-content: flex-start;
  padding-top: 40rpx;
}
.left-comment{
  width: 70rpx;
  margin-right: 20rpx;
}
.left-comment .avatar{
  width: 70rpx;
  height: 70rpx;
  border-radius: 50%;
}
.right-comment{
  flex:1;
}
.username-rate{
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.username{
  font-size:36rpx;
  margin-right: 20rpx;
  
}
.release-time{
  color: #b3b3b3;
  font-size:32rpx;
  margin-top: 10rpx;
}
.content{
  color:#353535;
  font-size:32rpx;
  margin-top: 10rpx;

}

onecomment.json

{
  "component": true,
  "usingComponents": {
    "stars":"../../component/stars/stars"
  }
}

onecomment.js

// component/onecomment/onecomment.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {

   item: {
      type: Object,
      value: []
  },
  },

page页

首页,全部采取自定义组件,直接套用,不需要再设定样式,结构简单

jiaohu.wxml



 
 
 

jiaohu.json

 

{
  "usingComponents": {
    "Taps":"../../component/Taps/Taps",   
    "indexmodule": "../../component/indexmodule/indexmodule"
  
  
  }
}

jiaohu.js

// pages/jiaohu/jiaohu.js
import{network}from "../../utils/network.js"
const app=getApp();
Page({

  /**
   * 页面的初始数据
   */
  

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    var that=this;
    network.getMovieList({
     
      success:function(movies){
        console.log(movies)
        that.setData({
          movies:movies
        }) 
      }
    })
    network.getTvList({
      success:function(tvs){
        console.log(tvs)
        that.setData({
         tvs:tvs
        })
      }
    })
    network.getShowList({
      success:function(shows){
        console.log(shows)
        that.setData({
          shows:shows
        })
      }
    })
}

更多页面

more.wxml




	

more.wxss

/* pages/more/more.wxss */
.container{
  display: flex;
  justify-content: space-between;
  flex-wrap:wrap;
  flex-direction: row;
  padding: 10rpx;
}
.iterview_block{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

more.json

{
  "usingComponents": {
    "Taps":"../../component/Taps/Taps",
    "iterview": "../../component/Iterview/Iterview"
  }
}

more.js

// pages/more/more.js
import{network}from "../../utils/network.js"
Page({

  /**
   * 页面的初始数据
   */
  data: {

  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    console.log(options)
     var that=this;
    var type =options.type;
    this.setData({
      type:type
    })
    wx.showLoading({
      title:"正在加载中..."
    })
    var title='';
    if(type==='movie'){
      title='电影 '
      network.getMovieList({
        count:1000,
        success:function(movies){
          that.setData({
            items:movies
          })
          wx.hideLoading();
        
        }
      })
    }  else if(type==='tv'){
      title='电视剧 '
      network.getTvList({
        count:1000,
        success:function(tvs){
          that.setData({
            items:tvs
          })
          wx.hideLoading();
        }
      })

    }else{
      title='综艺 '
      network.getShowList({
        count:1000,
        success:function(shows){
          that.setData({
            items:shows
          })
          wx.hideLoading();
        }
      })
    }
    wx.setNavigationBarTitle({
      title: title,
    })
  },

详情页

detail.wxml



	{{item.title}} {{item.original_title}} ({{item.year}})
	
		
			
				

				{{item.rating.count}}人评价
			
			
				{{item.durations[0]}} {{item.genres}}
				{{item.pubdate[0]}}上映{{item.countries[0]}}
				{{item.authors}}
			
		
		
			
		
	
  
     豆瓣成员常用标签
     
       {{item}}
     
  

  
   短评({{totalComment}})
    
  
  查看更多短评


detail.wxss

/* pages/detail/detail.wxss */
.item-header{
  padding:60rpx 30rpx

}
.item-title{
  font-size: 50rpx;
}
.item-detail{
  display: flex;
  justify-content: space-between;
  margin-top: 20rpx;
}
.left-detail{
  margin-right: 20rpx;
  flex: 1;
}
.item-rate{
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.right-detail{
  width: 200rpx;
  height: 300rpx;

}
.right-detail image{
  width: 100%;
  height: 100%;
}
.person{
  font-size: 28rpx;
  color: #ccc;
  margin-left: 20rpx;

}
.item-sub-detail{
  margin-top: 40rpx;
  font-size: 32rpx;
}
.item-sub-detail view{
  margin-bottom: 10rpx;
}

.item-tags{
  padding: 0 30rpx;
}
.item-tags .item-tags-title{
  color: #b3b3b3;
  font-size: 32rpx;
  margin-bottom: 20rpx;
}
.item-tags .item-tags-list{
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.item-tags-list text{
  padding: 10rpx;
  background: #f5f5f5;
  font-size: 32rpx;
  color: #353535;
  text-align: center;
  border-radius: 40rpx;
  margin-right: 20rpx;
  margin-bottom: 20rpx;
}

/* 短评信息展示 */
.comment-list-group{
  padding: 60rpx 30rpx;

}
.comment-list-group .comment-title{
  font-size: 32rpx;
  color: #b3b3b3;
}
.more-comment{
  text-align: center;
  font-size: 36rpx;
  color: #41be57;
  margin-bottom: 60rpx;
}

detail.json

{
  "usingComponents": {
    "stars": "../../component/stars/stars",
    "onecomment": "../../component/onecomment/onecomment"

  }
}

detail.js

// pages/detail/detail.js
import{network}from "../../utils/network.js"
Page({

  /**
   * 页面的初始数据
   */
  data: {
   
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    console.log(options);
    var type=options.type;
    var id=options.id;
    this.setData({
      type:type,
      id:id
    })
    var that=this;
    network.getItemDetail({
      id:id,
      type:type,
      success(item){
        console.log(item);
        var genres=item.genres;
        genres=genres.join("/");
        item.genres=genres;
        var actors=item.actors;
        var actorNames=[];
        if(actors.length>3){
          actors=actors.slice(0.3);

        }
        for(var index=0;index

短评组件

comment.wxml



  
   
   {{title}}
   {{rate}}分
  
  全部影评({{total}})
  
  
    
    

  

comment.wxss

/* pages/comment/comment.wxss */
.container{
  padding: 20rpx 30rpx;
}
.item-group{
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
 .item-group .thumbnail{
  width: 40rpx;
  height: 50rpx;
}
 .item-group .item-title{
  font-size: 32rpx;
  color: #41be57;
  margin-left: 10rpx;
  margin-right: 10rpx;
}
.item-group .item-rate{
  font-size: 28rpx;
  color: #ccc;
}
.comment-title{
  margin-top: 60rpx;
  font-size: 40rpx;
}
.page-btn-group{
  margin-top: 40rpx;
  margin-bottom: 40rpx;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.page-btn{
  flex: 1;
  height: 60rpx;
  color: #898989;
  border-color: #898989;
  line-height:60rpx ;
}

comment.json

{
  "usingComponents": {
    "onecomment": "../../component/onecomment/onecomment"

  }
}

comment.js

// pages/comment/comment.js
import {network} from"../../utils/network.js";
Page({

  /**
   * 页面的初始数据
   */
  data: {
    total:0,
    start:1,
    count:20

  },
  getComments:function(start){
    var that=this;
    var type=that.data.type;
    var id=that.data.id;
    if(start>that.data.start){
      that.setData({
        nextLoading:true   //下一页的数据请求
      })
    }else{
      that.setData({
        preLoading:true
      })
    }
    network.getItemComments({
      type:type,
      id:id,
      count:20,
      success:function(data){
        var total=data.total;
        var comments=data.interests;
        that.setData({
          total:total,
          comments:comments,
          start:start,
          nextLoading:false,
          preLoading:false
        })
        wx.pageScrollTo({
           scrollTop:0,
        })
      }
    })
  },
  onPrePageTap:function(){  //上一页
     var that=this;
     var oldstart=that.data.start
     var count=that.data.count;
     if(oldstart-count>0){
       var start=oldstart-count;
       that.getComments(start)
     }
  },
  onNextPageTap:function(){
    var that=this;
    var oldstart=that.data.start
    var start=oldstart+that.data.count;
    that.getComments(start)
  },
  onTap:function(){
    wx.navigateBack({
    
    })
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    console.log(options)
    this.setData(
      options
    )
    this.getComments(1);
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})

搜索页

 

微信小程序模仿豆瓣评分使用网络请求数据页面交互传值_第3张图片

search.wxml



  
    历史记录
    清除
  
  {{item.title}}


  
    
    
      {{item.title}}
      {{item.rating.value}}分/{{item.year}}
    
  

search.wxss

/* pages/search/search.wxss */

.item-list-group{
  padding: 10rpx 20rpx;
}
.item-list-group .item-group{
  padding: 10rpx 0;
  border-bottom: 1px solid #e4e4e4;
  display: flex;
}
.item-group .thumbnail{
  width: 80rpx;
  height: 100rpx;
  margin-right: 20rpx;
}
.item-group .info-group{
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.info-group .title{
  font-size: 32rpx;
}
.info-group .rate-year{
  font-size: 28rpx;
  color: #7b7b7b;
}
.history-list-group{
  padding: 10rpx 20rpx;
}
.history-list-group .history-title{
  display: flex;
  justify-content: space-between;
  padding: 20rpx 0;
  background: #f9f9f9;
  font-size: 28rpx;
  color: #9e9e9e;
}
.history-list-group .history-group{
  font-size: 32rpx;
  padding: 20rpx 0;
  border-bottom: 1px solid #e4e4e4;
}

search.json

{
  "usingComponents": {
    "Taps": "../../component/Taps/Taps"
  }
}

search.js

// pages/search/search.js
import {network} from "../../utils/network.js";
Page({

  /**
   * 页面的初始数据
   */
  data: {

  },
  onSearchInputEvent: function(event){
    var that = this;
    var value = event.detail.value;
    if(!value || value === ""){
      that.setData({
        subjects: null
      });
      return;
    }
    network.getSearch({
      q: value,
      success: function(subjects){
        that.setData({
          subjects: subjects
        })
      }
    })
  },
  onItemTapEvent: function(event){

    var that = this;
    var id = event.currentTarget.dataset.id;
    var type = event.currentTarget.dataset.type;
    var title = event.currentTarget.dataset.title;
    var histories = that.data.histories;
    var isExisted = false;
    if(histories){
      for(var index=0;index

app.js

//app.js
App({
  onLaunch: function () {
    // 展示本地存储能力
    var logs = wx.getStorageSync('logs') || []
    logs.unshift(Date.now())
    wx.setStorageSync('logs', logs)

    // 登录
    wx.login({
      success: res => {
        // 发送 res.code 到后台换取 openId, sessionKey, unionId
      }
    })
    // 获取用户信息
    
  },
  globalUrl: {
    doubanUrl: "https://m.douban.com/rexxar/api/v2"
  
  }
})

utils工具包

封装网络接口,方便page页调用

network.js

 import{globalUrls}from "urls.js"
const network={
  getItemDetail:function(params){
    var type=params.type;
    var id =params.id;
    var url='';
    if(type==="movie"){
      url=globalUrls.movieDetail+id
    }else if (type==='tv'){
      url=globalUrls.tvDetail+id

    }else{
      url=globalUrls.showDetail+id
    }
    wx.request({
      url:url,
      success:function(res){
        var item=res.data;
        params.success(item)
      }
    })
  },
  //获取电影列表
  getMovieList:function(params){
    params.type='movie'
    this.getItemList(params)
       
  },
  //获取电视剧列表
  getTvList:function(params){
    params.type='tv'
    this.getItemList(params)
       
  },
  //获取综艺列表
  getShowList:function(params){
    params.type='show'
    this.getItemList(params)
       
  },
  getSearch: function(params){
    var q = params.q;
    var url = globalUrls.searchUrl(q);
    wx.request({
      url: url,
      success: function(res){
        var subjects = res.data.subjects;
       
          params.success(subjects);
        
      }
    })
},

  getItemList:function(params){
  var count=params.count?params.count:7// 获取count数量值
  var url='';
  if(params.type==='movie'){
    url=globalUrls.movieList;

  }else if (params.type==='tv'){
    url=globalUrls.tvList;
  }else{
    url=globalUrls.showList;
  }
  wx.request({
    url: url,
    data:{
      count:count
    },
    success:function(res){
      console.log(res)
      var items=res.data.subject_collection_items
      var itemsCount=items.length;
      if(itemsCount%3===2){
        items.push(null)
      }
      if(params&¶ms.success){
        params.success(items)
      }
    }
  })
  },
  getItemTags:function(params){
    var type=params.type;
    var id=params.id;
    var url="";
    if(type==='movie'){
      url=globalUrls.movieTags(id);

    }else if(type==='tv'){
      url=globalUrls.tvTags(id);
    }else{
      url=globalUrls.showTags(id);
    }
    wx.request({
      url: url,
      success:function(res){
        var tags=res.data.tags;
        if(params.success){
          params.success(tags);
        }else{
          console.log("获取信息失败");
        }
      }
    })
  },
  getItemComments:function(params){
    var type=params.type;
    var id=params.id;
    var start=params.start?params.start:0;
    var count=params.count?params.count:3;
    var url=" ";
    if(type==='movie'){
      url=globalUrls.movieComments(id,start,count);
    }else if(type==='tv'){
      url=globalUrls.tvComments(id,start,count);
    }else{
      url=globalUrls.showComments(id,start,count)
    }
    wx.request({
      url:url,
      success:function(res){

        var data =res.data;
        if(params.success){
          params.success(data);
        }
      }

    })
  }
  
}
export{network}

urls.js

const globalUrls={
  movieList:"https://m.douban.com/rexxar/api/v2/subject_collection/movie_showing/items",
  tvList:"https://m.douban.com/rexxar/api/v2/subject_collection/tv_hot/items",
  showList:"https://m.douban.com/rexxar/api/v2/subject_collection/tv_variety_show/items",
  searchUrl:function(q){
    return"https://m.douban.com/rexxar/api/v2/search?q="+q

  },
  movieDetail:"https://m.douban.com/rexxar/api/v2/movie/",
  tvDetail:"https://m.douban.com/rexxar/api/v2/tv/",
  showDetail:"https://m.douban.com/rexxar/api/v2/tv/",
  movieTags: function(id){
    return "https://m.douban.com/rexxar/api/v2/movie/"+ id +"/tags?count=8"
  },
  tvTags: function(id){
    return "https://m.douban.com/rexxar/api/v2/tv/"+id+"/tags?count=8"
  },
  showTags: function(id){
    return this.tvTags(id);
  },

  movieComments:function(id,start=0,count=3){
    return 'https://m.douban.com/rexxar/api/v2/movie/' + id + '/interests?count=' + count + '&start=' + start;
  },
  tvComments:function(id,start=0,count=3){
    return 'https://m.douban.com/rexxar/api/v2/tv/' + id + '/interests?count=' + count + '&start=' + start;
  },
  showComments:function(id,start=0,count=3){
    return this.tvComments(id,start,count);
  }

  


}
export{globalUrls}

 

你可能感兴趣的:(微信小程序)