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

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

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

一、项目最终效果展示

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

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

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

推荐阅读更多精彩内容