小程序 – 笔记

前言

最近有在做小程序相关的内容,小程序是微信自己开发的一套标准。但是里面是兼容ES6语法的,因为之前有去学习React-Native的相关内容,所以就又去了解了ES6的相关内容。貌似有点跑题了?。话说回来,小程序是比React-Native简单的。可能没有写过前段代码的同学,不太习惯这种写法。

先上图

这里我在网上找了相关接口,做了一个类似内涵段子客户端的小程序。

大致的目录结构是这样的

这里说一下注意的点:

  • 现在的小程序开发工具(v1.02.1803210),当你把新建好的目录拖到别的目录时,自己为文件添加的内容会被删除。所以,大家在修改目录的时候一定要注意。
  • 当你修改文件名的时候,被调用的地方文件名并不会被修改。
  • 往项目里面添加外部资源只能打开对应的文件夹才行
  • 因为版本更迭的原因,当你进入有底部Tab的页面时需要使用
//跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
wx.switchTab(OBJECT)
  • template模板文件

这个标签有点类似Android中的include标签,把公共的UI部分抽离出来,其他地方也可以使用

  • 在使用template时,在外面套一层view
<view>
  <template is="loadingTemplate" data="{{...loadingState}}" />
</view>

因为template只是占位符,运行起来时,是没有template标签的,所以,当我们要添加一些事件时,需要加在它的外层view上面。

  • JS引用JS文件
var requestUtils = require('../../utils/RequestUtils.js');
  • 引用模板文件
<import src="../loading/loading-template.wxml" />

最后是一个/>闭区间,小程序开发工具不会自动给你添加?。

  • 引用样式文件
@import "../loading/loading-template.wxss";
  • data传值只能传一个对象过去 比如:
<template  name="loadingTemplate">
  <view class='loading-container'  hidden='{{!loading}}'>
    <image src='../../images/icon/icon-loading.png' class='loading-img'></image>
    <view class='loading'>正在加载...</view>
  </view>
  <view class='loadingComplete' hidden='{{!loadingComplete}}'>已全部加载</view>
</template>

上面我在模板文件中使用了loadingloadingComplete两个变量。如果要传值的话,就要像下面这样。

<template is="loadingTemplate" data="{{...loadingState}}" />

这里的loadingState是一个对象

var loadingState={
  loading: loading,
  loadingComplete: loadingComplete
}
this.setData({
  loadingState:loadingState
}
  • this的作用域问题 大家写Android都知道,当我们在内部类中调用Toast时,填写Context是不能直接写this的。因为this指的是当前类。
btn.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
       Toast.makeText(Activity.this, "", Toast.LENGTH_SHORT).show();
    }
 });

小程序中也一样,在一个方法内部调用外部方法的时候,就不能用this,需要声明一个变量保存this,然后再使用这个变量。类似下面这样。

getDataList: function () {
    let that = this;
    requestUtils.getRequestUrl(ctype, page, function (data) {
      if (data.data.length === 0) {
        that.setData({
          loadingState: that.changeLoadingState(false,true)
        })
      } else {
        var list = [];
        list = that.data.dataList.concat(data.data);
        that.parseData(list);
      }
    })
  },

最后的最后,遇到问题先冷静一下(遇到问题很正常),仔细查看小程序官网。很多问题都会迎刃而解。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏刘望舒

Retrofit2与服务端实例讲解

网络上对 Retrofit2 的各种介绍文章已经很多了,不过往往只是对其用法进行介绍,而缺少相应的实践,这一方面是因为网络上的免费API接口返回的数据格式和访问...

953
来自专栏Flutter入门到实战

开发工具总结(6)之Android Studio模板配置详解(提高开发效率必备技能)

版权声明:本文为博主原创文章(部分引用他人博文,已加上引用说明),未经博主允许不得转载。https://www.jianshu.com/p/1fe87050c1...

972
来自专栏技术碎碎念

T-SQL 查询、修改数据表

T-SQL修改表数据 INSERT语句 语法: INSERT [TOP(expression) [PERCENT]] [INTO] ...

4194
来自专栏battcn

MySQL - WHERE优化篇

在做JAVA开发中,通过指令重拍会对代码做一定程度的优化,在数据库中 MYSQL优化器也做了一系列相关优化工作,下面要介绍的就是数据库做的内置优化

802
来自专栏C/C++基础

MySQL问题集锦

(1)SELECT子句是必选的,其它子句如WHERE子句、GROUP BY子句等是可选的。

662
来自专栏青枫的专栏

Eclipse 生成Javadoc乱码问题

在 Eclipse 的开发使用中,我们经常使用的是 UTF-8 编码,但是刚刚安装的或者是导入的项目是其他编码的默认是 GBK 的,这就造成我们的项目乱码,一些...

591
来自专栏开发之途

Retrofit2与服务端实例讲解

1215
来自专栏LanceToBigData

MySQL(八)之DML

昨天晚上很晚的时候才写完MySQL的常用函数,今天给大家讲一下MySQL的DML。接下来让我们直接来学习了,今天感冒了。身体很难受下午的时候要去买一波药了,不然...

1829
来自专栏资深Tester

增删改查的查之简单查询

1333
来自专栏Hongten

SQL SERVER事务处理

事务三种运行模式: 自动提交事务 每条单独的语句都是一个事务。 显式事务 每个事务均以 BEGIN TRANSACTION 语句显式开始, 以 COMMIT 或...

692

扫码关注云+社区