微信小程序开发笔记持续更新中...

前言

   小程序已经火了一段时间了,各大厂商也纷纷推出自己的小程序。想想前端好难啊,天天都要面对新知识,不学习就要掉队,这些天整理公司的小程序项目发现好多点又忘记了~~~心塞塞。所以痛定思痛写做些笔记吧,供大家参考也自己总结下。

1、导入

   这里我觉得有必要理解几个概念 export、export default、 module.eports的区别不过多的解释看module.exports 和 exports,export 和export default的区别。require与import的区别 require和import的区别
上代码:

// data.js
let  processForms = [{...}]

module.exports = { 
    processForms
 }

// form.js
import formData from "./data.js";
2、调试AppData

微信开发者里面的使用工具AppData,可以很方便的查看当前数据变化


AppData
组件标签样式警告
组件样式警告

  提示很明显了,机制问题,改成用class就好了

3、覆盖第三方组件样式

   目前因为微信机制问题【作用域考虑】,在自定义组件中在调用第三方组件,并重写组件样式的话是有问题的。目前有三种方式解决
1、修改第三方组件抛出externalClasses 【不建议】
2、使用标签书写样式有效,但是会报上面组件标签样式警告 【不建议】
3、自己在页面定义class,及书写第三方组件样式可行

4、setData 动态下标的使用

官网介绍方法

changeItemInArray: function() {
    // you can use this way to modify a danamic data path
    this.setData({
      'array[0].text':'changed data'
    })
  },
  changeItemInObject: function(){
    this.setData({
      'object.text': 'changed data'
    });
  },

看到这个的时候我第一反应是js的拼接,but 行不通

 this.setData({
      'array['+index+'].text':'changed data'
})

可行的做法是,这种魔鬼中的细节只有看文档多实操积累撒【sa】

let itemText =  'array['+index+'].text';
 this.setData({
      [itemText]:'changed data'
})
5、容器点击事件穿透【事件捕获】

   这里的事情有点扯,按事件的类型来区分的话应该是事件捕获,但是小程序里面点击的明明button 的父容器,却触发了button事件,所以这里我叫他事件穿透。

点击容器触发了button事件

解决:在容器上阻止冒泡,catchtap 一个空事件
推荐了解浏览器中事件的冒泡

6、textarea 等原生组件穿透浮层【层级最高】

   场景:真机中在页面中使用textarea ,里面的placeholder或者内容会漂浮在浮层(弹窗框Mask之类)之上,很恶心啦。
   官方的解释是textarea是原生组件层级最高撒


小程序原生组件

目前官方给出的方案是使用 <cover-view>、<cover-image>,这个个人感觉能解决一部分需求,但是局限【限制】有点大。以下整理了网上的几种方案:

1、cover-view 方式
2、隐藏方式,也就是在mask开启时,隐藏原生组件反正都开启浮层了。不过页面可能会闪,对于有强迫症的可能会接受不了撒
3、在2的基础上扩展一下,写个元素占位,mask的时候显示元素占位来替代原生组件【还可以focus 的时候,这个自己想了,思路很多,下面是我项目DEMO部分】

<!--textarea.wxml-->
<view class="textarea-box">
    <textarea class="textarea" wx:if="{{focusFlag}}" focus="{{focusFlag}}" value="{{item.defaultValue}}" placeholder="{{item.placeholder}}" disabled="{{item.readonly}}" maxlength="{{item.len}}" bindinput="inputChange" bindblur="textareaBlur"></textarea>
    <view class="placeholder" wx:if="{{!focusFlag}}" catchtap="textareaFocus">{{item.defaultValue ? item.defaultValue: item.placeholder}}</view>
  </view>
/*textarea.wxss*/
.textarea-box {
  position: relative;
  height: 200rpx;
  overflow: hidden;
}


.textarea, .placeholder {
  width: 100%;
  border: 1rpx solid #ddd;
  padding: 28rpx 34rpx;
  height: 200rpx;
  box-sizing: border-box;
  border-radius: 20rpx;
  font-size: 28rpx;
  font-family: PingFang SC;
  font-weight: 400;
  color: rgba(102, 102, 102, 1);
}

.placeholder {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  word-break: break-all;
  overflow: auto;
}

  目前主流是这三种方式,如果你有更好的方式,欢迎来搞。

7、小程序{{}}内使用函数

  为什么会有这个需求呢?写过Vue的同学应该用用过filter在页面做数据处理,好处是简单,看的直白。bug小程序中没有啊。原来小程序提供了另外一种方式.wxs文件处理。举栗

/*
* utils.wxs
* 大家应该发现了,我这里用的都是es5的语法low?
* 应该这个文件就是这么有个性es6不行哈
*/
var getIsNumber = function(ele) {
  if (ele === "" || ele == null) {
    return false
  }
  if(!isNaN(ele)){
    return true
  } else {
    return false
  }
}

module.exports = {
  getIsNumber: getIsNumber
}

  .wxs文件有了这么用呢找个页面试试啥

/* 
* test.wxml 
* 就这么简单粗暴
*/
<wxs src="../../utils.wxs" module ="utils"/>
...
<view wx:for="arr" wx:key="index">{{utils.getIsNumber(item.type)}}</view>
...
8、npm 构建

  这个是因为这几天移动了项目目录,用cnpm install后再构建发现不行,所以你懂得npm install撒

9、组件内canvas 失效

   这是个很有意思的事情,在页面中使用canvas都正常,把事件抽到自定义组件里面,canvas失效了,my god!
   查了一下原来是作用域的问题,组件内要指定this。

1、 const query = wx.createSelectorQuery().in(this)
这一句是最重要的,要用 in(this),this传入的是自定义组件的实例,否则获取到的rect值为null。

ready: function() {
    const query = wx.createSelectorQuery().in(this)
    query.select('.search-content').boundingClientRect(rect=>{
      console.log(rect.height)
    }).exec();
}

2、canvasToTempFilePath: fail canvas is empty。 类似

wx.canvasToTempFilePath({
          canvasId: 'canvasId',
          success: (res) => {
          },
          fail: (res) => {
          }
   },this);
10、获取小程序页面栈
let pages=getCurrentPages();//页面指针数组
let prepage=pages[pages.length-2];//上一页面指针
prepage.setData({
….
});
11、小程序selector 选择

  selector 类似于 CSS 的选择器,但仅支持下列语法。

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

推荐阅读更多精彩内容