小程序开发之你需要掌握的基础知识点

wx.jpg

最近学习了慕课网《微信小程序入门与实战——常用组件API开发技巧项目实战》这个课程,对于小程序有了一个比较新的认识,在课程中我碰到的一些问题,与大家分享一下。

1,事件是否冒泡

事件分为冒泡事件和非冒泡事件

  • 冒泡事件:当一个组件上的事件被触发后,该事件会向父节点传递。
  • 非冒泡事件:当一个组件上的事件被触发后,该事件不会向父节点传递。

有的时候我们不想要事件冒泡,因为会影响我们的效果。

小程序帮我们解决了,bind事件绑定不会阻止冒泡事件向上冒泡,catch事件绑定可以阻止冒泡事件向上冒泡。

// 事件冒泡
<view class="journey-container" bindtap="onTap">
     <text class="journey">开启小程序之旅
     </text>
</view>

// 事件非冒泡
<view class="journey-container" catchtap="onTap">
     <text class="journey">开启小程序之旅
     </text>
</view>

要是想了解哪些事件是冒泡事件或者非冒泡事件,大家可以参考文档小程序事件


2,元素上的属性节点获取:currentTargettarget

先了解两个属性:

  • currentTarget:事件绑定的当前组件。
  • target:触发事件的源组件。

比如我们给每一个元素赋值了一个值,如下我们想要拿到data-alpha-betadata-alphaBeta,当我们我们想要拿到这个在当前元素上的值。

<view data-alpha-beta="1" data-alphaBeta="2" bindtap="bindViewTap"> DataSet Test </view>

我们可以通过event.currentTarget.dataset获得到,

Page({
  bindViewTap:function(event){
    event.currentTarget.dataset.alphaBeta === 1 // - 会转为驼峰写法
    event.currentTarget.dataset.alphabeta === 2 // 大写会转为小写
  }
})

但是如果是下面的这种情形:我们的事件是写在swiper组件上的时候,但是我们想要通过点击image获得其上面的data-postId,我们就需要通过event.target.dataset.postid

<swiper catchtap="onSwiperTap" >
    <swiper-item>
        <image id="7" src="/images/wx.png" data-postId="3"></image>
    </swiper-item>
    <swiper-item>
        <image src="/images/vr.png" data-postId="4"></image>
    </swiper-item>
</swiper>

target指的是当前点击的组件 和currentTarget 指的是事件捕获的组件,target这里指的是image,而currentTarget指的是swiper


3,底部tab栏设置

tabbar.png

这个还是比较简单的,只要在App.json进行相应的tabBar配置就行了。

{
  "pages": [
    "pages/index/index",
    "pages/logs/logs"
  ],
  "tabBar": {
    "borderStyle": "white",
    "position": "bottom",
    "list": [
      {
        "pagePath": "pages/posts/post",
        "text": "阅读",
        "iconPath": "images/tab/yuedu.png",
        "selectedIconPath": "images/tab/yuedu_hl.png"
      },
      {
        "pagePath": "pages/movies/movies",
        "text": "电影",
        "iconPath": "images/tab/dianying.png",
        "selectedIconPath": "images/tab/dianying_hl.png"
      }
    ]
  }
}

4,尺寸单位:rpx

在小程序的里面,我们使用rpx来代替px,官方的定义如下:

rpx(responsive pixel): 可以根据屏幕宽度进行自适应。规定屏幕宽为750rpx。如在 iPhone6 上,屏幕宽度为375px,共有750个物理像素,则750rpx = 375px = 750物理像素,1rpx = 0.5px = 1物理像素。

如果想要更加了解,大家可以参考微信小程序开发--从px到rpx


5,图片轮播事件:swiper

swiper.gif
<swiper 
    vertical="{{false}}" 
    indicator-dots="true" 
    autoplay="true" 
    interval="5000"
>
    <swiper-item>
        <image id="7" src="/images/wx.png" data-postId="3"></image>
    </swiper-item>
    <swiper-item>
        <image src="/images/vr.png" data-postId="4"></image>
    </swiper-item>
    <swiper-item>
        <image src="/images/iqiyi.png" data-postId="5"></image>
    </swiper-item>
</swiper>

这个就能够实现一个最最简单的图片轮播。

上面的swiper的一些属性:

  • vertical:滑动方向是否为纵向
  • indicator-dots:是否显示面板指示点
  • autoplay:是否自动切换
  • interval:自动切换时间间隔

更多的参数大家可以参考微信小程序——swiper


6,上拉加载,下拉刷新。

scroll.gif
  • 上拉加载

    • 如果你使用的是<scroll-view>组件:他有一个事件叫做:bindscrolltolower,滚动到底部/右边,会触发 scrolltolower 事件。
    // wxml
    <scroll-view class="grid-container" scroll-y="true" scroll-x="false" bindscrolltolower="onScrollLower">
      // 你的代码
    </scroll-view>
    
    // wxss
    ...
    onScrollLower: function (event) {
        var nextUrl = this.data.requestUrl +
          "?start=" + this.data.totalCount + "&count=20";
        util.http(nextUrl, this.processDoubanData)
        wx.showNavigationBarLoading()
    },
    ...
    
    • 如果你使用<view>,你就不需要在元素里面绑定任何事件,直接在js文件里面申明:
    ...
    onReachBottom: function (event) {
        var nextUrl = this.data.requestUrl +
          "?start=" + this.data.totalCount + "&count=20"; // 请求借口,加载数据,并更新数据
        util.http(nextUrl, this.processDoubanData);
        wx.showNavigationBarLoading(); // 显示loading
    },
    ...
    
  • 下拉刷新

    在你需要的进行下拉刷新的页面的json文件里面:

    {
      "enablePullDownRefresh": true
    }
    

    然后在js中,进行相应的数据操作:

    ...
    onPullDownRefresh: function (event) {
        var refreshUrl = this.data.requestUrl +
          "?start=0&count=20";
        this.data.movies = {};
        this.data.isEmpty = true;
        this.data.totalCount = 0;
        util.http(refreshUrl, this.processDoubanData);
        wx.showNavigationBarLoading();
    },
    ...
    


6,音乐播放api

music.gif

文档中讲的很详细了微信小程序——音乐

music-audio.png
music2.png

这里面的监听音乐播放的api很重要,举一个简单的例子,当整首音乐播放完了的时候,我们设置相应的数据状态,来改变前端的相应的ui变化;这些方法都是需要配合使用的。


7,缓存

数据缓存.png

每个微信小程序都可以有自己的本地缓存,可以通过wx.setStorage(wx.setStorageSync)wx.getStorage(wx.getStorageSync)wx.clearStorage(wx.clearStorageSync)可以对本地缓存进行设置、获取和清理。同一个微信用户,同一个小程序 storage 上限为 10MB。localStorage 以用户维度隔离,同一台设备上,A 用户无法读取到 B 用户的数据。

总共有8个关于缓存的方法,4个是同步的,4个是异步的。

如下图,不过基本上我们用到缓存,都是同步的方法,异步的时候太难预测,除非是一些特定的业务场景。

wx.setStorageSync("posts_collected", postsCollected); // 设置缓存

var postsCollected = wx.getStorageSync("posts_collected"); // 读取缓存

wx.clearStorage(); // 清除缓存

8,Toastmodal的显示

modal.gif

如下,通过

  //data数据
  data: {
     postCollected:false, // 是否收藏了文章
  },
  
  // modal
  showModal: function (postCollected) {
    var that = this;
    wx.showModal({
          title: "收藏",
          content: postCollected ? "收藏该文章?" : "取消收藏该文章?",
          showCancel: "true",
          cancelText: "取消",
          cancelColor: "#333",
          confirmText: "确认",
          confirmColor: "#405f80",
          success: function (res) {
            if (res.confirm) {
              // modal点击了成功
            }
          }
        })
  }
    
  // Toast
  showToast: function (postCollected) {
    // this.setData({
    //   collected: postCollected
    // })

    wx.showToast({
      title: postCollected ? "收藏成功" : "取消成功",
      duration: 1000,
      icon: "success"
    })
  },

具体的modal的属性大家可以参考官方文档


9,template语法

template.png

这样的一个页面可以分成三个template写,一个是星星star-template,我标了1;一个是单个电影页面的movie-template,我标了2;最后是一个三列的电影列表movie-list-template,我标了3.

如下:

star-template:星星组件

star.png

movie-template:单个电影页面

movie.png

movie-list-template:电影列表

movie-list.png

10,数据绑定

微信小程序中,ui的显示都是依靠数据绑定来完成了,没有Dom这个概念。

比如控制一个图片的显示与否:

// wxml
<image class="head-image" src="{{isPlayingMusic?postData.music.coverImg : ''}}"></image>

// js
...
data: {
    isPlayingMusic: false
},
...

如果我们是根据接口来获取数据的,我们在接口回调成功之后去设置我们data中的数据:

this.setData({
    movies: totalMovies
});

如下图:

我们首先通过访问接口,接口成功之后,调用回调方法。

util.png

对返回的结果进行处理之后,set相应的data

setdata.png

后记

此篇文章是参考是我在看了小程序实战视频之后,我是直接拿课程的代码来讲上述的知识点的,我记录了自己遇到最多问题,同时也附加上了自己的一些理解。

希望这篇文章对大家学习小程序能有帮助,来自一个奔跑在前端路上的前端小白。

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