小程序开发实例技巧(三)横向滑动列表加载读取本地json数据

上一篇文章中我们已经学会了横向滑动切换列表效果的实现,但是我们显示在页面的数据是在js里写死的数据,实际项目中这里一般是请求后台接口返回的数据。我们通过接口给后台传递参数,比如栏目类型,分页大小与页码,搜索人物的关键词等,然后后台给我们返回符合条件的列表,我们把返回的数据展示到前台。


但是有时候我们需要模拟数据时,我们可以自己在本地造一些假数据供我们调试。

第一步:新建一个文件夹存放我们要加载的json数据


json数组数据如下:

var authorList =
  [
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔0",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔1",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔2",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔3",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔4",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔5",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔6",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔7",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔8",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
    {
      img: "http://ookzqad11.bkt.clouddn.com/avatar.png",
      name: "欢顔9",
      tag: "知名情感博主",
      answer: 134,
      listen: 2234
    },
  ]

第二步:在json_data.js里导出我们需要的json数据,

/*导出方法 */
module.exports = {
  authorList: authorList
}

第三步:在所需要展示数据页面的js里引入json数据并存到当前页面的变量里

/*引入本地定义的json数据的js*/
var exportData = require("../../data/json_data.js");

Page({
  data: {
    /*将json数据赋值存到本地供页面使用*/
    authorList: exportData.authorList
  }
})

test.js完整代码:

/*引入本地定义的json数据的js*/
var exportData = require("../../data/json_data.js")
var app = getApp();
Page({
  data: {
    winHeight: "",//窗口高度
    currentTab: 0, //预设默认选中的栏目
    scrollLeft: 0, //tab滚动条距离左侧距离
    newsTab: ["健康", "情感", "职场", "育儿", "文学","青葱","科技","达人"],
    /*将json数据赋值存到本地供页面使用*/
    authorList: exportData.authorList
  },
  // 滚动切换标签样式
  switchTab: function (e) {
    this.setData({
      currentTab: e.detail.current
    });
    this.checkCor();
  },
  // 点击tab切换当前页时改变样式
  swichNav: function (e) {
    var cur = e.target.dataset.current;
    if (this.data.currentTab == cur) {
      return false;
    }
    else {
      this.setData({
        currentTab: cur
      })
    }
  },
  //判断当前滚动超过一屏时,设置tab向左滚动。
  checkCor: function () {
    if (this.data.currentTab > 4) {
      this.setData({
        scrollLeft: 300
      })
    } else {
      this.setData({
        scrollLeft: 0
      })
    }
  },
  onLoad: function () {
    var that = this;
    //  高度自适应
    wx.getSystemInfo({
      success: function (res) {
        var clientHeight = res.windowHeight,
          clientWidth = res.windowWidth,
          rpxR = 750 / clientWidth;
        var calc = clientHeight * rpxR - 180;
        that.setData({
          winHeight: calc
        });
      }
    });
  }
})

第四步:在页面渲染列表

test.wxml代码:

<view>
  <scroll-view scroll-x="true" class="tab-h" scroll-left="{{scrollLeft}}">
    <block wx:for-items="{{newsTab}}">
      <view data-current="{{index}}" class="tab-item {{currentTab == index ?'active':''}}" bindtap="swichNav" >
        {{item}}
      </view>
    </block>
  </scroll-view>
  <swiper class="tab-content" current="{{currentTab}}" duration="300" bindchange="switchTab" style="height:{{winHeight}}rpx">
    <!--两次for循环嵌套,由于要在第二层里使用第一层循环的对象,所以给第一层循环的对象取别名author,方便后面调用 -->
    <swiper-item wx:for="{{authorList}}" wx:for-item="author">
      <scroll-view scroll-y="true" class="scoll-h">
       <!-- 每一栏目默认展示9条,循环显示9次 -->
        <block wx:for="{{[0,1,2,3,4,5,6,7,8]}}" wx:key="*this">
          <view class="item">
            <view class="img">
              <image src="{{author.img}}"></image>
            </view>
            <view class="author-info">
              <view class="name">{{author.name}}{{index+1}}</view>
              <view class="tag">{{author.tag}}</view>
              <view class="answerHistory">{{author.answer}}个回答,{{author.listen}}人听过 </view>
            </view>
            <navigator url="" class="shouting">关注</navigator>
          </view>
        </block>
      </scroll-view>
    </swiper-item>
  </swiper>
</view>

这里值得注意的是:

两层for循环嵌套,由于要在第二层里使用第一层循环的对象,所以给第一层循环的对象取别名author,方便后面调用

样式表test.wxss代码如下:

.tab-h {
  height: 100rpx;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
  line-height: 80rpx;
  background: #f7f7f7;
  font-size: 16px;
  white-space: nowrap;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
}
.tab-item {
  margin: 0 36rpx;
  display: inline-block;
}
.tab-item.active {
  color: #4675f9;
  position: relative;
}
.tab-item.active:after {
  content: "";
  display: block;
  height: 8rpx;
  width: 66rpx;
  background: #4675f9;
  position: absolute;
  bottom: 0;
  left: 5rpx;
  border-radius: 16rpx;
}
.tab-content {
  margin-top: 100rpx;
}
.tab-content .author-info{
  font-size: 12px;
  flex-grow: 3;
  color: #b0b0b0;
  line-height: 1.5em;
}
.tab-content .author-info .name {
  font-size: 16px;
  color: #000;
  margin-bottom: 6px;
}
.item {
  display: flex;
  width: 100%;
  padding: 30rpx;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  border-bottom: 1px solid #f2f2f2;
}
.img {
  width: 100rpx;
  height: 100rpx;
  position: relative;
  padding-right: 30rpx;
}
.img image {
  width: 100%;
  height: 100%;
}
.shouting {
  width: 120rpx;
  height: 60rpx;
  line-height: 60rpx;
  text-align: center;
  font-size: 14px;
  border-radius: 60rpx;
  border: 1px solid #4675f9;
  color: #4675f9;
}
.scoll-h {
  height: 100%;
}

原文作者技术博客:https://www.jianshu.com/u/ac4daaeecdfe
95后前端妹子一枚,爱阅读,爱交友,将工作中遇到的问题记录在这里,希望给每一个看到的你能带来一点帮助。
欢迎留言交流。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,192评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,858评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,517评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,148评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,162评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,905评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,537评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,439评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,956评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,083评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,218评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,899评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,565评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,093评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,201评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,539评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,215评论 2 358

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,941评论 2 89
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,498评论 1 45
  • 概要 64学时 3.5学分 章节安排 电子商务网站概况 HTML5+CSS3 JavaScript Node 电子...
    阿啊阿吖丁阅读 9,216评论 0 3
  • 英英释义:the most basic and important quality of something ...
    哇620阅读 573评论 0 0
  • 直到阳光把我晒成一滩黑水 直到我被天空收留 直到我重新以水的形式 降落 到你的伞上 你的发丝上 你也不知道谁是我 ...
    粮食和花圈阅读 246评论 0 0