美文网首页我爱编程前端
微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换

微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换

作者: 我追求的小世界 | 来源:发表于2018-03-09 11:33 被阅读0次

    大家好,决定在这里码码字,写写文章啦,希望和大家一起交流分享~

    最近在学习微信小程序,在这里记录下学习到的知识点,欢迎大家指正~

    一、项目最终效果展示

    github地址:https://github.com/haogjin/Douban-Movie/tree/master

    注:

    1. 这里主要展示"热映"界面效果,其中"找片"和"我的"界面效果没有展示,"找片"的效果与"热映"基本技术操作是一样的。
    2. 主要知识点:flex布局、可滚动视图组件scroll-view、自定义组件(调用及传值)。

    二、开始开发项目

    环境搭建

    创建自己的第一个小程序只需要2步即可:1.申请账号,2.安装开发者工具。
    这里就不多说啦,传送门:https://mp.weixin.qq.com/debug/wxadoc/dev/

    项目结构说明

    整体项目结构:

    说明(这里只做简要说明,具体在后面讲解):

    1. conponents--自定义组件文件夹
    2. images--图片文件夹
    3. pages--页面文件夹 所有的页面都放在pages文件夹下,每个页面包括 .js(js文件)、 .wxml(页面模板文件,相当于h5的html文件) 、 .wxss(页面样式文件,相当于h5的css文件)、 .json文件(页面配置文件);pages文件夹下的index(首页)和logs(日志)文件夹是搭建环境时自动生成的,但本项目没使用到这个页面,请知悉。
    4. styles--公共样式文件夹
    5. utils--公共js文件
    6. app.js--项目入口文件
    7. app.json--小程序全局配置文件
    8. app.wxss--全局样式文件 如果有共同使用的样式文件可以写在这个文件里,当然也可以自己创建样式文件进行引用。
    9. project.config.json--工具配置 每个项目的根目录都会生成一个 project.config.json,用于保存当前项目的所有配置,保证载入项目的时候同步开发项目时的个性化配置。

    开始开发

    一、实现底部tab页
    一共包含3个tab页:热映、找片、我的。
    1.在pages文件夹下建立home、finding、user文件夹,并分别创建相应文件。

    2.在app.json文件中配置新建的三个文件的路径。

    说明:
    1)所有新增的页面都必须在pages里面注册,否则无法显示,建议新建一个页面立即在pages里面注册,以免忘记。这里pages是一个数组,第一个元素即为当前显示的页面。
    2)在app.json文件的pages中注册后的相应.js文件需要定义相应的Page:

    Page({
      data: {
    
      },
      onLoad: function (options) {
    
      },
      onReady: function () {
    
      },
      onShow: function () {
    
      },
      onHide: function () {
    
      },
      onUnload: function () {
    
      }
      //.....
    })
    

    可以参照环境搭建好之后生成的index.js代码,在其中可以定义属性和事件,具体后续会讲解。

    3)window字段说明:用于配置小程序所有页面的顶部背景颜色,文字颜色等,这里用到的属性说明:

    backgroundTextStyle : 下拉背景字体、loading 图的样式,仅支持 dark/light
    navigationBarBackgroundColor :导航栏背景色
    navigationBarTitleText:导航栏标题
    navigationBarTextStyle:导航栏标题颜色,仅支持 black/white

    注:注册保存后相应文件夹就会自动生成对应页面的.json文件,可以对当前页面进行局部配置,当然也可以手动新建。

    1. 在app.json中配置tab
     "tabBar": {
        "backgroundColor": "#dfdfdf",
        "color": "#8a8a8a",
        "selectedColor": "#000000",
        "list": [
          {
            "text": "热映",
            "iconPath": "images/ing.png",
            "selectedIconPath": "images/ing-active.png",
            "pagePath": "pages/home/home"
          },
          {
            "text": "找片",
            "iconPath": "images/find.png",
            "selectedIconPath": "images/find-active.png",
            "pagePath": "pages/finding/finding"
          },
          {
            "text": "我的",
            "iconPath": "images/user.png",
            "selectedIconPath": "images/user-active.png",
            "pagePath": "pages/user/user"
          }
        ]
      }
    

    说明:

    1. 三个tab项需要放置于list数组中。
    2. color表示文本颜色,selectedColor表示选中文本的颜色。
    3. iconPath表示位于text上方的图标路径,selectedIconPath表示选中tab的图标路径。
    4. 图标库推荐: Iconfont-阿里巴巴矢量图标库

    完整的app.json文件:("debug":true表示开启调试模式)

    {
      "pages":[
        "pages/home/home",
        "pages/finding/finding", 
        "pages/user/user", 
        "pages/index/index",
        "pages/logs/logs"
      ],
      "window":{
        "backgroundTextStyle":"light",
        "navigationBarBackgroundColor": "#dfdfdf",
        "navigationBarTitleText": "豆瓣电影",
        "navigationBarTextStyle":"black"
      },
      "tabBar": {
        "backgroundColor": "#dfdfdf",
        "color": "#8a8a8a",
        "selectedColor": "#000000",
        "list": [
          {
            "text": "热映",
            "iconPath": "images/ing.png",
            "selectedIconPath": "images/ing-active.png",
            "pagePath": "pages/home/home"
          },
          {
            "text": "找片",
            "iconPath": "images/find.png",
            "selectedIconPath": "images/find-active.png",
            "pagePath": "pages/finding/finding"
          },
          {
            "text": "我的",
            "iconPath": "images/user.png",
            "selectedIconPath": "images/user-active.png",
            "pagePath": "pages/user/user"
          }
        ]
      },
      "debug":true
    }
    

    到这里tab页面切换就完成啦,是不是很简单~~~

    为了验证正确性,分别编辑home.wxml、finding.wxml、user.wxml文件:

    /* <view>标签表示视图容器,相当于<div>标签 */
    /* home.wxml */
    <view class="fa fa-book">热映界面</view>
    
    /* finding.wxml */
    <view class="fa fa-eye">找片界面</view>
    
    /* user.wxml */
    <view class="fa fa-user">用户界面</view>
    

    其中 class="fa fa-user" 表示引入font Awesome图标,引入方法:https://www.jianshu.com/p/936e3f09e217
    当然也是可以引用iconfont字体的,看个人选择~

    对应的界面:

    home.png finding.png user.png

    当然也可以加入各种样式,方式与h5基本没区别。

    今天就先到这里啦~

    接着会抓取豆瓣电影数据展示电影正在热映和即将上映列表及详情,如果文中有什么不对的或者需要注意的地方欢迎大家指正,一起分享交流~
    接下文 微信小程序仿豆瓣电影页面demo(2)--实现"正在热映"与"即将上映"切换:
    https://www.jianshu.com/p/0eff6f592d53

    版权声明:本文为作者原创文章,未经允许不得转载。如需转载,请联系作者并标明出处及原链接!

    相关文章

      网友评论

        本文标题:微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换

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