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

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

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

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

一、项目最终效果展示

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/

项目结构说明

整体项目结构:

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

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

  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文件夹,并分别创建相应文件。

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

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

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

说明:
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文件:

/* 标签表示视图容器,相当于
标签 */ /* home.wxml */ 热映界面 /* finding.wxml */ 找片界面 /* user.wxml */ 用户界面

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

对应的界面:

微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换_第5张图片
home.png
微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换_第6张图片
finding.png
微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换_第7张图片
user.png

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

今天就先到这里啦~

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

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

你可能感兴趣的:(微信小程序仿豆瓣电影页面demo(1)--底部导航tab切换)