「趣学前端」小程序开发的喜怒哀乐2.0版本

本文涉及的产品
.cn 域名,1个 12个月
简介: 用技术实现梦想,用梦想打开创意之门。分享小程序开发中如何封装组件。

前言

前篇介绍了小程序开发的基础功能,第二篇分享小程序开发中如何封装组件。


小程序功能


日期选择器

picker组件可以实现日期选择器的功能,可以设置可选的日期范围,只要设置开始和结束两个时间点即可,注意,时间范围在真机模拟中才生效。官方文档

如下图为我在小程序中加入的日期选择器的交互界面,我设置的是往前可选到两年前,往后只能选到当前月。

image.jpeg

travelList.wxml

使用picker组件将事件点击区域包裹起来,这样点击就可以触发日期选择的弹窗,bindchange事件绑定的是进行日期选择之后的操作

<pickermode="date"fields="month"value="{{ date }}"start="{{ createStartTime }}"end="{{ createEndTime }}"bindchange="getDateTime"><viewclass="head"><viewclass="head-left">{{ searchTimeText }}</view><viewclass="arrow-icon"><imagesrc="../../images/icon/icon-arrow.png"></image></view></view></picker>

travelList.js

searchTimeText:页面展示的日期变量;

createStartTime:日期选择器可选的最早日期,格式为yyyy-MM;

createEndTime:日期选择器可选的最晚日期,格式为yyyy-MM;

getDateTime: 日期选择器的确定操作的回调方法,返回值格式为yyyy-MM。


constdate=newDate();
varyear=date.getFullYear();
varmonth=date.getMonth();
varminValue=newDate().getTime() -2*365*24*60*60*1000;
varmaxValue=newDate().getTime();
Page({
/**   * 页面的初始数据   */data: {
searchTimeText: `${year}年${month+1}月`, // 页面展示日期createStartTime: util.dateFormatter(minValue, 'yyyy-MM'), // 可选的最早日期createEndTime: util.dateFormatter(maxValue, 'yyyy-MM'), // 可选的最晚日期  },
// 选择日期getDateTime: function (e) {
console.log('picker发送选择改变,携带值为', e.detail.value);
letvalue=e.detail.value;
letlist=value.split('-');
letsyear=list[0];
letsmonth=list[1];
// 重新请求列表数据并设置年份回显this.setData({
searchTimeText: `${syear}年${smonth}月`,
    });
  },
});

modal弹窗

基础的modal弹窗

wx.showModal可以实现modal弹窗,直接在点击事件中调用即可。官方文档

可以自定义弹窗标题、弹窗内容、成功回调处理、失败回调处理等

比如在我的旅游小程序中,用户跳转自己的游记页面,我需要判断这个用户有没有写过游记,如果没有需要给出提示。

mine.html

<viewclass="mine-content-item"bindtap="gotoTravel"><viewclass="content-item-label"><text>我的游记</text><textclass="ml5">({{ travelList.length }})</text></view><viewclass="arrow-icon"><imagesrc="../../images/icon/icon-arrow.png"></image></view></view>

mine.js

当列表数据没有数据的时候给出提示。

// 跳转我的游记列表gotoTravel() {
if (this.data.travelList.length===0) {
wx.showModal({
title: '温馨提示',
content: '您暂时还没有发表游记,是否跳转热门游记?',
success(res) {
if (res.confirm) {
wx.redirectTo({
url: '../travelList/travelList?type=hot',
          });
        } elseif (res.cancel) {
console.log('用户点击取消');
        }
      },
    });
  } else {
wx.redirectTo({
url: '../travelList/travelList?type=self',
    });
  }
},


最终的弹窗提示如图:

image.jpeg


自定义modal弹窗

wx.showModal提供的能力中,展示内容是字符串类型,如果我们需要展示的内容比较复杂,那么wx.showModal就无法满足我们的需求了,这个时候需要自定义弹窗。

我仿照掘金的展示模块,给我的旅游小程序加了一个个人成就的栏位,功能是展示文章被赞和被阅读的数量,交互如下:

image.jpeg


image.jpeg


实现的方案就是在wxml中把弹窗的布局写出来,通过wx:if进行内容是否展示的控制。

mine.wxml

<viewclass="mine-content-item"bindtap="remarkShow"><viewclass="content-item-label">个人成就</view><viewclass="arrow-icon"><imagesrc="../../images/icon/icon-arrow.png"></image></view></view>...<!--个人成就-弹窗--><viewwx:if="{{ achievementShowFlag }}"class="remark-view"><viewclass="remark-view-background"><viewclass="remark-view-top">个人成就</view><viewclass="remark-view-middle"><viewclass="item"><viewclass="label">文章被点赞:</view><viewclass="text">{{ achievement.praise }}</view></view><viewclass="item"><viewclass="label">文章被阅读:</view><viewclass="text">{{ achievement.view }}</view></view></view><viewclass="remark-view-bottom"><viewclass="remark-view-cancel"bindtap="remarkClose">关闭</view></view></view></view>

mine.wxss

.remark-view {
height: 100vh;
width: 100%;
background: rgba(0, 0, 0, 0.5);
z-index: 999;
position: fixed;
top: 0;
}
.remark-view-background {
background: white;
height: 30%;
margin: 60%48rpx0;
border-radius: 8rpx;
}
.remark-view-top {
padding: 20rpx32rpx0;
font-size: 36rpx;
color: #0b1d32;text-align: center;
font-weight: bold;
}
.remark-view-middle {
margin: 40rpx32rpx0;
height: 50%;
border-radius: 8px;
font-size: 32rpx;
font-weight: 200;
}
.remark-view-middle .item {
margin-bottom: 10rpx;
display: flex;
justify-content: space-between;
justify-items: center;
}
.remark-view-blank {
height: 1rpx;
margin-top: 65rpx;
background: #dfe2e4;}
.remark-view-bottom {
height: 80rpx;
border-radius: 8px;
font-size: 18px;
width: 100%;
border-top: 2rpxsolid#f4f4f4;}
.remark-view-cancel {
line-height: 80rpx;
color: #0b1d32;font-weight: 200;
font-size: 30rpx;
text-align: center;
}
.remark-view-confim {
width: 50%;
line-height: 80rpx;
color: #0a73f5;font-weight: 200;
font-size: 30rpx;
}

mine.js

  • 设置两个参数分别是个人成就内容对象-achievement和人成就弹窗是否展示布尔值-achievementShowFlag;
  • 两个方法,打开弹窗方法:remarkShow和关闭弹窗方法:remarkClose
/**   * 页面的初始数据   */data: {
achievement: {}, // 个人成就achievementShowFlag: false, // 个人成就弹窗是否展示 默认-false  },
// 个人成就弹窗-打开remarkShow() {
this.setData({
achievementShowFlag: true,
achievement: {
praise: 30,
view: 1200,
          },
      });
  },
// 个人成就弹窗-关闭remarkClose() {
this.setData({
achievementShowFlag: false,
    });
  },

2.2.7 拨打手机号

小程序拨打电话的API是wx.makePhoneCall,官方文档

值如果是固定的比如客服,可以定义全局的常量,方便统一维护,如果是需要从接口动态获取的,直接通过接口获取并赋值即可。

我再util文件下面新增了一个常量文件-constant.js,用于维护我的项目中的公共常量。

constant.js

定义全局的客服电话

/** * @description 公共常量 *//** @name 客服电话 */exportconstservicePhone='400-xxx-xxx';

mine.wxml

在需要拨打电话的页面,绑定唤起拨打电话功能的方法:phoneCall

<viewclass='mine-content-item'bindtap='phoneCall'><textclass='content-item-label'>联系客服(待开发)</text><viewclass='arrow-icon'><imagesrc='../../images/icon/icon-arrow.png'></image></view></view>

mine.js

constconstant=require('../../utils/constant.js');
// 拨打客服电话phoneCall() {
constphoneNumber=constant.servicePhone;
wx.makePhoneCall({
phoneNumber: phoneNumber,
    });
},


多选组件

普通多选

官方提供了checkbox组件,支持单个多选框和多选组,官方文档

官方提供的示例基本把用法都列出来了

wxml文件

<viewclass="container"><viewclass="page-body"><viewclass="page-section page-section-gap"><viewclass="page-section-title">默认样式</view><labelclass="checkbox"><checkboxvalue="cb"checked="true"/>选中</label><labelclass="checkbox"><checkboxvalue="cb"/>未选中</label></view><viewclass="page-section"><viewclass="page-section-title">推荐展示样式</view><viewclass="weui-cells weui-cells_after-title"><checkbox-groupbindchange="checkboxChange"><labelclass="weui-cell weui-check__label"wx:for="{{items}}"wx:key="{{item.value}}"><viewclass="weui-cell__hd"><checkboxvalue="{{item.value}}"checked="{{item.checked}}"/></view><viewclass="weui-cell__bd">{{item.name}}</view></label></checkbox-group></view></view></view>  </view>

js文件

Page({
onShareAppMessage() {
return {
title: 'checkbox',
path: 'page/component/pages/checkbox/checkbox'    }
  },
data: {
items: [
      {value: 'USA', name: '美国'},
      {value: 'CHN', name: '中国', checked: 'true'},
      {value: 'BRA', name: '巴西'},
      {value: 'JPN', name: '日本'},
      {value: 'ENG', name: '英国'},
      {value: 'FRA', name: '法国'}
    ]
  },
checkboxChange(e) {
console.log('checkbox发生change事件,携带value值为:', e.detail.value)
constitems=this.data.itemsconstvalues=e.detail.valuefor (leti=0, lenI=items.length; i<lenI; ++i) {
items[i].checked=falsefor (letj=0, lenJ=values.length; j<lenJ; ++j) {
if (items[i].value===values[j]) {
items[i].checked=truebreak        }
      }
    }
this.setData({
items    })
  }
})


展示效果

image.jpeg

二维数组的多选

我的小程序里面用到多选的数据是一个二维数组,选择城市的页面,城市数据含城市首字母大写,我尝试之后发现checkbox组件对二维数组也是支持的

cityList.wxml

checkbox-group需要把整个数组包起来,才能正常获取选中项,我刚开始只把最里面的循环包起来了,发现拿到的选中项的数据不对。

<checkbox-groupbindchange="checkboxChange"class="checkbox-box"><viewclass="weui-cells weui-cells_after-title"wx:for="{{ list }}"wx:key="index"wx:for-item="item"wx:if="{{ list.length > 0 }}"><textclass="scroll-letter">{{ item.firstLetter }}</text><labelclass="weui-cell weui-check__label scroll-item checkbox-item"wx:for="{{item.list}}"wx:key="cityIndex"wx:for-item="city"><viewclass="weui-cell__hd"><checkboxvalue="{{city.cityId}}"checked="{{city.checked}}"/></view><viewclass="weui-cell__bd">{{ city.cityName }}</view></label></view></checkbox-group>

cityList.js

list:城市列表二维数组,包含城市首字母大写

// pages/cityList/cityList.jsPage({
/**   * 页面的初始数据   */data: {
list: [
          {
firstLetter: 'A',
list: [
              {
cityId: 3,
cityName: '毕节市',
provinceId: 3,
provinceName: '贵州省',
              },
            ],
          },
          {
firstLetter: 'B',
list: [
              {
cityId: 4,
cityName: '安顺市',
provinceId: 3,
provinceName: '贵州省',
              },
            ],
          },
          {
firstLetter: 'G',
list: [
              {
cityId: 5,
cityName: '贵阳市',
provinceId: 3,
provinceName: '贵州省',
              },
            ],
          },
          {
firstLetter: 'L',
list: [
              {
cityId: 6,
cityName: '六盘水市',
provinceId: 3,
provinceName: '贵州省',
              },
            ],
          },
          {
firstLetter: 'T',
list: [
              {
cityId: 7,
cityName: '铜仁市',
provinceId: 3,
provinceName: '贵州省',
              },
            ],
          },
          {
firstLetter: 'Z',
list: [
              {
cityId: 8,
cityName: '遵义市',
provinceId: 3,
provinceName: '贵州省',
              },
            ],
          },
        ], // 城市列表  },
});

UI展示

image.jpeg

全选、部分选中、删除已选项

在多选的基础上做全选、部分选中的功能是可行的,处理会复杂一些,由于文章篇幅的问题,我就不具体列出来了,文章底部我放置了我的小程序git地址,大家可以拉代码看,交互效果如下

部分选中

image.jpeg

全选

image.jpeg


自定义组件

组件化编程,重复功能组件化,复杂功能组件化拆分,都有利于代码的维护和提升开发效率,微信也提供了自定义组件的功能。官方文档


创建自定义组件

  • 打开微信开发者工具,我把我的自定义组件都放到了component目录下,在该目录下右键点击,选新建Component,然后命名组件,命名成功之后就会生成组件文件结构,如下图,我命名的组件是stars;
  • 类似于页面,一个自定义组件由 jsonwxml、wxssjs 4个文件组成。

image.jpeg

  • 要编写一个自定义组件,首先需要在 json 文件中进行自定义组件声明(将 component 字段设为 true 可将这一组文件设为自定义组件):
{
"component": true}


开发自定义组件

Component 构造器可用于定义组件,调用 Component 构造器时可以指定组件的属性、数据、方法等。详细的参数含义和使用请参考 Component 参考文档

以我小程序中的评价功能为例。评价功能设计的交互为点了星星,界面展示如下,选择了三个城市,点亮了两个城市的评价最后一个没有点亮:

image.jpeg

stars.wxml

星星使用的是图片,点亮和不点亮是两张不同的图片

<viewclass="stars-view"><viewclass="flex"wx:for="{{ imgs }}"wx:key="id"wx:for-item="item"bindtap="_changeColor"data-index="{{ item.id }}"><imageclass="canSelect ? big-star : litter-star"src="{{ item.id > starCount ? starNoSelect : starSelect }}"></image></view></view>

stars.wxss

/* component/stars/stars.wxss */.stars-view {
display: flex;
align-items: center;
}
.flex {
display: flex;
align-items: center;
}
.big-star {
width: 44rpx;
height: 44rpx;
margin: 0px8rpx;
vertical-align: middle;
}
.litter-star {
width: 36rpx;
height: 36rpx;
margin: 0px4rpx;
vertical-align: middle;
}

stars.js

  • properties组件的对外属性,是属性名到属性设置的映射表
  • methods组件的方法,包括事件响应函数和任意的自定义方法,关于事件响应函数的使用,参见 组件间通信与事件。其中微信的建议是内部方法建议以下划线开头。
// component/stars/starts.jsComponent({
/**   * 组件的属性列表   */properties: {
//是否可以点击canSelect: {
type: Boolean,
value: true,
    },
//星星个数starCount: {
type: Number,
value: 5,
    },
// 当前引用组件的子项的索引 当父组件是数组时有效index: {
type: Number,
value: 0,
    },
  },
/**   * 组件的初始数据   */data: {
imgs: [
      {
id: 1,
      },
      {
id: 2,
      },
      {
id: 3,
      },
      {
id: 4,
      },
      {
id: 5,
      },
    ],
starNoSelect: '/images/icon/star-noSelect.png',
starSelect: '/images/icon/star-select.png',
  },
/**   * 组件的方法列表   */methods: {
// 更新星星颜色 内部方法建议以下划线开头_changeColor: function (e) {
letstarCount=e.currentTarget.dataset.index;
this.setData({
starCount: starCount,
      });
letmyEventDetail= {
starCount: starCount,
index: this.data.index,
      };
this.triggerEvent('myevent', myEventDetail);
    },
  },
});

使用自定义组件

使用已注册的自定义组件前,首先要在页面的 json 文件中进行引用声明。此时需要提供每个自定义组件的标签名和对应的自定义组件文件路径:

activityFavorite.json

{
"usingComponents": {
"stars": "../../component/stars/stars"  },
"navigationBarTitleText": "评选喜爱城市"}

在页面的 wxml 中就可以像使用基础组件一样使用自定义组件。节点名即自定义组件的标签名,节点属性即传递给组件的属性值。

activityFavorite.wxml

<viewwx:for="{{ cityList }}"wx:key="index"wx:for-item="item"class="item"><viewclass="item-left">{{ item.cityName }}</view><starscanSelect="{{ item.stars == 0 }}"starCount="{{ item.stars }}"bind:myevent="setStartCount"index="{{ index }}"></stars></view>


自定义组件见通信

组件间的基本通信方式有以下几种。

  • WXML 数据绑定:用于父组件向子组件的指定属性设置数据,仅能设置 JSON 兼容数据(自基础库版本 2.0.9 开始,还可以在数据中包含函数)。具体在 组件模板和样式 章节中介绍。
  • 事件:用于子组件向父组件传递数据,可以传递任意数据。
  • 如果以上两种方式不足以满足需要,父组件还可以通过 this.selectComponent 方法获取子组件实例对象,这样就可以直接访问组件的任意数据和方法。

上面的评价组件中,

1.子组件向父组件通信中,使用 triggerEvent 方法进行事件触发,每次操作评价点亮时,都会触发通信。

// 更新星星颜色 内部方法建议以下划线开头_changeColor: function (e) {
letstarCount=e.currentTarget.dataset.index;
this.setData({
starCount: starCount,
  });
letmyEventDetail= {
starCount: starCount,
index: this.data.index,
  };
this.triggerEvent('myevent', myEventDetail);
},

2.父组件通过监听拿到子组件传过来的值

// 事件监听setStartCount: function (e) {
letdetail=e.detail; // 子组件通信传的值letcityList= [].concat(this.data.cityList);
cityList[detail.index].stars=detail.starCount;
this.setData({
cityList: cityList,
    });
  },


wxs

WXS(WeiXin Script)是小程序的一套脚本语言,结合 WXML,可以构建出页面的结构。我开始理解的它有点像filter过滤器,但是后面做了一些尝试,发现它的功能挺强大的。官方文档

类似filter过滤器用法

比如我想做一个颜色过滤器,某些特定文字展示蓝色,其余展示灰色,于是我在comm.wxs文件中写了一个方法

comm.wxs

/** * 设置详情页顶部右侧文案颜色 * @param {string} text 右侧文字内容 * @return {string} color 文字颜色 */functionsetRightTextColor(text) {
varcolor='#999';
if (text&&text.indexOf('发布') !==-1) {
color='#0a73f5';
  }
returncolor;
}
module.exports= {
setRightTextColor: setRightTextColor,
};

cityDetail.wxml

wxml文件中使用,需要先引入,我习惯外部文件放到底部,其实官方放到了顶部。这样一来detail.source的值中有发布二字的会展示蓝色

<wxssrc="../../wxs/comm.wxs"module="comm"/><viewclass="head"><viewclass="head-left">{{ detail.describe }}</view><viewclass="head-right"style="color:{{comm.setRightTextColor(detail.source)}}">{{ script.getShowText(detail.source) }}</view></view>

页面展示

蓝色

image.jpeg

灰色

image.jpeg


其他用法

wxs也可以直接在wxml文件里写功能,比如我想加一个默认文案展示的处理,当接口返回的数据中某个变量的值为空时,展示默认文案,可以直接wxml里面写一个方法,然后进行调用

cityDetail.wxml

<!--wxs显示默认文案--><wxsmodule="script">vargetShowText=function(text, defaultText='内容摘自百度百科') {
varshowText=showText?showText : defaultText;
returnshowText;
  }
module.exports.getShowText=getShowText;
</wxs><viewclass="container"><viewclass="banner"><viewclass="banner-box"><viewclass="head"><viewclass="head-left">{{ detail.describe }}</view><viewclass="head-right"style="color:{{comm.setRightTextColor(detail.source)}}">{{ script.getShowText(detail.source) }}</view></view></view></view></view>


开放能力

小程序开发需要对官方提供的开放能力做一定调研,比如某些功能只有非个人开发者才能使用,如:获取手机号;比如某些功能是特定基础库之后才有的,如小程序加密网络通道功能是从基础库 2.17.3 开始支持的;某些功能需要在小程序管理后台申请,比如分享数据到微信运动,需要到小程序管理后台,「开发」-「接口设置」中自助开通该组件权限。 只针对「体育-在线健身」类目的小程序开放。

所以要关注小程序开放能力以及某些功能的调整。官方文档


如何解决小程序开发遇到的问题

导航条不展示

我在app.josn里加上导航条之后,如下为导航条代码

"tabBar": {
"selectedColor": "#007AF5",
"list": [
      {
"pagePath": "pages/home/home",
"text": "首页",
"iconPath": "/image/icon/home-unselected.png",
"selectedIconPath": "/image/icon/home-selected.png"      },
      {
"pagePath": "pages/mine/mine",
"text": "我的",
"iconPath": "/image/icon/mine-unselected.png",
"selectedIconPath": "/image/icon/mine-selected.png"      }
    ]
  },

发现导航条无法正常展示页面路径也空了,还报了一个错误,如下截图

image.jpeg


image.jpeg

我尝试把导航条内容删除,页面就正常了,于是我推测是iconpath的问题,果然我的文件夹名字是images但是这里我写成了image,改完重新编译,页面就能正常显示了

image.jpeg

因为导航条这里的代码并不是很多,遇到问题可以首先考虑iconPath的路径是否正确。


解决webview导致的不支持打开非业务域名的问题

1.问题如图:

image.jpeg

2.问题原因

小程序后台没有设置业务域名,小程序中使用了webview功能,需要配置业务域名,如果没有配置那么在操作小程序的时候会出现上图的提示。其他webview功能可以看官方文档

3.怎么看自己有没有配业务域名

两种方法

1)直接到小程序后台查看

开发管理->开发设置->业务域名模块,是否已配置了自己需要跳转的域名。注:只有企业认证的小程序采用业务域名模块,个人小程序没有。

2)开发者工具

在项目配置中有一项叫做web-view(业务域名)如果设置了会展示已经设置的域名,如果没设置会展示未设置

image.jpeg

4.如何设置业务域名

小程序后台,开发管理->开发设置->业务域名模块

1)点击开始配置按钮

image.jpeg


2)下载校验文件


请下载校验文件,并将文件放置在域名根目录下,例如wx.qq.com,并确保可以访问该文件。如配置中遇到问题,请查看具体指引。

image.jpeg


如何配置用户隐私保护指引设置中的使用用户信息类型

1.用户信息类型有哪些

小程序发版前需要确认用户隐私保护指引设置已完成,且其中的使用用户信息类需要选全,如果不全可能会导致小程序审核失败,用户信息类型如下截图:

image.jpeg

2.如何知道自己都需要选择哪些用户信息类型

微信提供了API对应用户信息类型的详细文档,文档官方地址

具体内容如下,如果小程序中使用了某个接口,用户隐私保护指引设置的时候就需要勾选对应的用户信息类型了:

处理的信息

接口或组件

收集你的微信昵称、头像

wx.getUserInfo、wx.getUserProfile、<button open-type="userInfo">

收集你的位置信息

wx.authorize({scope:'scope.userLocation'})、wx.authorize({scope: 'scope.userLocationBackground'})、wx.getLocation、wx.startLocationUpdate、wx.startLocationUpdateBackground、wx.choosePoi、wx.chooseLocation

收集你的地址

wx.chooseAddress

收集你的发票信息

wx.chooseInvoiceTitle、wx.chooseInvoice

收集你的微信运动步数

wx.authorize({scope: 'scope.werun'})、wx.getWeRunData

收集你的手机号

<button open-type="getPhoneNumber">

收集你的车牌号

wx.chooseLicensePlate

收集你选中的照片或视频信息

wx.chooseImage、wx.chooseMedia、wx.chooseVideo

收集你选中的文件

wx.chooseMessageFile

访问你的麦克风

wx.authorize({scope: 'scope.record'})、wx.startRecord、RecorderManager.start、<live-pusher>、wx.joinVoIPChat

访问你的摄像头

wx.authorize({scope: 'scope.camera'})、wx.createVKSession、<camera>、<live-pusher>、<voip-room>

访问你的蓝牙

wx.openBluetoothAdapter、wx.createBLEPeripheralServer

使用你的相册(仅写入)权限

wx.authorize({scope: 'scope.writePhotosAlbum'})、wx.saveImageToPhotosAlbum、wx.saveVideoToPhotosAlbum

使用你的通讯录(仅写入)权限

wx.addPhoneContact

使用你的日历(仅写入)权限

wx.addPhoneRepeatCalendar、wx.addPhoneCalendar


解决微信小程序真机 showToast 不显示

原文地址:https://www.jianshu.com/p/ab511b0edaf9

作者:chenxuxu

链接:https://www.jianshu.com/p/ab511b0edaf9

来源:简书

简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

 

真机上测试发现调用 showToast 不显示,或者闪一下就没了。经过查找,发现是与 wx.showLoading 冲突了,两者调用的是同个框。

先放上我的错误代码:

// 请求事件requestEvent: function() {
wx.showLoading({
title: '正在加载中',
    })
wx.request({
url: '',
success: function(res) {
wx.showToast({
title: '成功',
duration: 2000        })
      },
fail: function() {
wx.showToast({
title: '失败',
duration: 2000        })
      },
complete: function() {
wx.hideLoading()
      }
    })
  }


我是想请求接口后,将加载框隐藏掉,再显示 toast 提示。但是真机上发现 showToast 不显示。正如上面所说,两者调用的是同个框。现在,我们分析整个流程:

  • 首先显示 loading 框;
  • 然后调用 success / fail,弹框的内容由 loading 变成了 toast;
  • 最后调用 onComplete 时,hideLoading 将弹框隐藏掉了.

很明显,我们最终把 toast 框隐藏掉了。知道原因后,改起来就容易了。先调用 wx.hideLoading(),再调用 wx.showToast() 即可


建议

1)若是在网络请求前需要调用 wx.showLoading,建议在该 success 和 fail 回调函数内第一行就调用 wx.hideLoading。即使暂时不需要 showToast 操作。因为以后需要在回调函数内添加 toast 时, 就不用再管什么顺序问题了;

2)当 toast 和 loading 同时使用,多注意两者的调用顺序;

如下是正确代码:

// 请求事件requestEvent: function() {
wx.showLoading({
title: '正在加载中',
    })
wx.request({
url: '',
success: function(res) {
// 放到最上面wx.hideLoading()wx.showToast({
title: '成功',
duration: 2000        })
      },
fail: function() {
wx.hideLoading()
wx.showToast({
title: '失败',
duration: 2000        })
      }
    })
  }


小程序过审注意事项

1.提交审核信息(非常重要)

  • 修改内容LOG一定要清晰完整
  • 有账户体系的小程序,必须支持微信登录,同时需要提供测试账号(微信审核人员不会主动注册账号进行审核的)
  • 版本号严谨,避免混乱

image.jpeg

2.代码质量

  • 减少代码内部必要的bug,比如那些devTool调试工具就可见的红字报错

如下截图为页面有bug时,审核未通过的原因

image.jpeg

  • APP.JSON中的pages页面一定要保证都能打开,如果没有内容需要展示无内容提醒,比如列表为空时,可以提示暂无数据,不可以展示空白页面;

如下截图为页面无法加载或者空白时,审核未通过的原因

image.jpeg

  • 避免小程序页面UI不规范,保证主流机型屏幕尺寸下,页面UI可以正常显示;

如下截图为页面UI显示不规范时,审核未通过的原因

image.jpeg



3.关注微信官方公告和政策

比如小程序的使用规范:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/channels-live.html#%E4%BD%BF%E7%94%A8%E8%A7%84%E8%8C%83

里面明确了

平台将坚决打击诱导跳转视频号直播、诱导预约视频号直播等行为,使用此功能时请严格遵守《微信小程序平台运营规范》


如下截图为小程序存在不符合规范的情况下,审核未通过的原因:

image.jpeg


4.开放的类目

  • 开发前,请先参考已经开放的类目,没有开放的类目审核会不通过
  • 部分类目需要资质,没有资质无法通过.

5.禁止测试性质的内容出现,禁止非正式的服务出现在小程序中

如下截图为小程序有测试性质内容下,审核未通过的原因:

image.jpeg

6.用户需要发表内容的小程序,需要设定关键词过滤,屏蔽掉政策不允许的内容

如下截图为小程序用户发布内容未进行关键词过滤,审核未通过的原因:

image.jpeg

7.视频,音乐等内容,不能设置为自动播放;

8.提供资讯的小程序,不能含有任何时政类的新闻

如下截图为小程序时包含政类的新闻,审核未通过的原因:

image.jpeg

9.假如审核通过,请立刻在后台发布;请勿在未发布审核通过的小程序时,就提交新版本审核,会导致无法发布。


总结


个人小程序git地址:https://github.com/wxmp-project/wxmp-travel

目前功能开发的还比较简单,后续会持续更新,文章也会持续更新,因为还有些功能由于还在摸索着,所以暂时没加。

目录
相关文章
预约按摩小程序开发,为什么很多上门按摩平台根本招聘不到优秀技师?
上门按摩平台面临招不到优秀技师的问题,主要原因是平台众多,技师选择多样。为解决此问题,平台可引入技师等级制度,根据订单数量和好评率划分高、低等级技师。高等级技师可享受70%-90%的高提成及首页推荐,这不仅能激励技师的积极性,还能帮助平台筛选出优质技师,提升服务质量和口碑,形成良性循环。
|
27天前
|
小程序 前端开发 数据可视化
作为一个前端小白,我竟然搞定了一个小程序的交付
作为一名刚毕业的前端码农,今年毕业后就加入了一家初创公司。入职不久便接到了一个小程序开发项目,客户特别强调必须使用小程序原生语言进行开发。由于时间紧迫而合适的后端开发者暂时还没到位,老板决定让我边学边做,承担起整个项目的前后端开发工作。对于初出茅庐的我来说,这无疑是一个巨大的挑战。不仅要掌握一门新的编程语言,还要学习数据库设计、服务器部署等一系列后端技术,任务艰巨。正当我为此感到头疼时,一位前辈向我推荐了极态云。经过一番调研后发现,它简直就是为像我这样缺乏后端经验但又急需快速完成项目的人量身定做的解决方案!
作为一个前端小白,我竟然搞定了一个小程序的交付
|
24天前
|
前端开发 JavaScript 安全
揭秘!前端大牛们如何高效解决跨域问题,提升开发效率!
【10月更文挑战第30天】在Web开发中,跨域问题是一大挑战。本文介绍前端大牛们常用的跨域解决方案,包括JSONP、CORS、postMessage和Nginx/Node.js代理,对比它们的优缺点,帮助初学者提升开发效率。
46 4
|
27天前
|
人工智能 小程序
【一步步开发AI运动小程序】五、帧图像人体识别
随着AI技术的发展,阿里体育等公司推出的AI运动APP,如“乐动力”和“天天跳绳”,使云上运动会、线上健身等概念广受欢迎。本文将引导您从零开始开发一个AI运动小程序,使用“云智AI运动识别小程序插件”。文章分为四部分:初始化人体识别功能、调用人体识别功能、人体识别结果处理以及识别结果旋转矫正。下篇将继续介绍人体骨骼图绘制。
|
28天前
|
人工智能 小程序 vr&ar
AI运动小程序开发常见问题集锦二
截至当前,我们的AI运动识别小程序插件已迭代至第23个版本,广泛应用于健身、体育、体测、AR互动等场景。本文针对近期用户咨询,汇总了常见问题,帮助用户减少开发成本,提高效率。主要涵盖计时与计数模式的区别、综合排行榜生成方法、全屏模式适配及无开发能力用户的解决方案。
|
28天前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。
|
2月前
|
存储 传感器 小程序
跳绳计数小程序开发系统
首先,我们需要明确跳绳计数小程序的核心功能:为用户提供跳绳计数的便捷方式。这意味着小程序需要能够准确地记录用户的跳绳次数,并为用户提供清晰、直观的计数展示。
|
2月前
|
人工智能 编解码 小程序
【一步步开发AI运动小程序】四、小程序如何抽帧
随着AI技术的发展,阿里体育等公司推出的“乐动力”、“天天跳绳”等APP使云上运动会、线上健身等概念备受关注。本文将引导您从零开始开发一个AI运动小程序,利用“云智AI运动识别小程序插件”。文中详细介绍了微信小程序抽帧的相关API、设置及注意事项,帮助开发者更好地实现AI运动功能。下篇将介绍人体识别技术,敬请期待。
|
2月前
|
传感器 存储 小程序
跳绳计数小程序开发
跳绳计数小程序旨在通过智能设备(如手机或智能手表)记录用户在跳绳过程中的次数、时间、速度等关键数据,为用户提供便捷的运动记录和数据分析服务
|
2月前
|
小程序 搜索推荐 前端开发
小剧场短剧影视小程序开发
小剧场短剧影视小程序旨在为用户提供一个便捷、互动的平台,让用户能够随时随地观看、分享和评论各类小剧场短剧。通过小程序,用户可以浏览热门短剧、搜索感兴趣的内容、参与社区互动,以及享受个性化的推荐服务。