1、结构

  • util.js       工具类
  • app.js          全局工具函数
  • app.json      小程序配置
  • app.wxss     全局样式

2、生命周期

  • onLoad(options)         页面加载时触发,可获取路径中的参数(1)
  • onReady()                  页面渲染完成(1)
  • onShow()                   页面显示/切入前台触发(N)
  • onHide()                     页面隐藏/切入后台时触发(N)
  • onPullDownRefresh() 监听用户下拉动作,此事件需要在app.json文件中window节点中"开启全局的下拉刷新"enablePullDownRefresh":true,才能触发它
  • onReachBottom()      上拉触底事件,需要当前页内容超过一屏幕
  • onPageScroll()           滚动事件
  • onShareAppMessage() 自定义分享
  • onUnload()                 页面写在

3、wx语法

    循环 
  • wx:for="{{}}"
  • wx:key="{{}}"            可以不写 写了节约性能
  • wx:for-index="key"   不写默认 index
  • wx:for-item="val"      不写默认item
    条件判断
  • wx:if="{{}}"
  • wx:elif="{{}}"
  • wx:else

4、模块引入

    import 方法
        定义模块
<template name=''> 内容{{}} </template>
            template  可以定义多个
        使用
 <import src='../' />
<template is='name' data='{{title:"sd"}}'/>
            is      模块名称
            data    数据
    include 方法
        <include src='./'>
            template 不生效

5、设置数据 this.setData({})

6、事件

    bind    冒泡
    catch   非冒泡
    常见事件:tap touch相关
    写法:bind:tap='click'

7、事件对象

    type               类型
    timeStamp          时间
    target            属性值
    currentTarget     属性值

8、属性类型

    Boolean  Number String Array Object EventHandler(事件处理函数名)

9、共同属性

    id class style hidden(隐藏) data-*(自定义属性) bind*/catch*

10、自定义组件

    1- 新加组件(工具新加component)
    2- 需要引入组件的页面配置文件 json中定义 name path,
 {
"usingComponents": {
// 在父模板中调用的标签名 组件的路径
"com-name": "path/to/the/custom/component"
}
}
    3- 页面中调用组件
        <com-name>

11、组建通信

    父级-子集
        原理:类似于vue  自定义属性--properties接收
        父级        <com-name name='测试'>    
        子集js文件 
            properties:{ name:{
                type:String,
                optionalTypes:[String,Number]
                value:'123'
            }}  
    子集-父级
        原理:类似于vue     自定义事件并(triggerEvent)传递---evt.detail
            子集:  
                <view data-name='son' bind:Tap='sonClick'></view>
                    sonClick(evt){
                        let name=evt.target.dataset.name
                        this.triggerEvent('getName',{name},false)
                    }
            父级:
                <com-name bind:getName='click'/>
                  click(evt){
                      let name=evt.detail
                  }  

12、wxs模块

    写法与js类似,不知此ES6
    tools.wxs
 function mysub(str,len){
return ...
}
module.exports={
mysub:mysub
}
    引入与使用
 <wxs src='../../tools.wxs' module='tools'/>
<view>tools.mysub('hfghaf')</view>

13、网络请求

    1-设置请求超时时间
        app.json
 "networkTimeout":{
"request":10000
}
    2-请求
        http.js
  const http = ({url,data={},method='Get',header={}})=>{
wx.showLoading({
title:'加载中'
})
return new Promise((resolve,reject)=>{
wx.request({
url,
method,
success:res=>{
resolve(res)
},
fail:()=>{
reject('fail')
},
complete:()=>{
wx.hideLoading()
}
})
})
}
    3-配置请求地址
        config uri.js
  const host = 'http://localhost/api/v1'
export default {
new:'${host}/news'
}
    4-请求模型
  models newsModels.js
            import http from '../utils/http'
import config from '../config/uri'
// 获取新闻列表
export const getNew=(page=1)=>{
return http({
url:config.news
})
}
    5-调用
      import {getNews} from '../../models/newsModel'
getNews().then(res=>{
this.setData({
news:res.data
})
})
14、缓存
    没有过期时间,单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB。
        class Cache {
/*
1、设置缓存
单位毫秒
*/
set(key, value, expire = 36000) {
expire = Date.now() + expire * 1000
//原有的数据改成对象,加上缓存时间
let data = { expire, value }
wx.setStorage({
key,
data, });
}
/*
2、获取缓存
*/
get(key) {
if (this.has(key)) {
return ''
}
return wx.getStorage(key).value
}
/*
3、清理缓存
*/
remove(key) {
wx.removeStorage({
key: key
});
}
}
            
        

微信小程序开发基础详解的更多相关文章

  1. 微信小程序开发之详解生命周期方法

    生命周期是指一个小程序从创建到销毁的一系列过程 在小程序中 ,通过App()来注册一个小程序 ,通过Page()来注册一个页面 先来看一张小程序项目结构 从上图可以看出,根目录下面有包含了app.js ...

  2. 微信小程序开发基础

    前言: 微信小程序开入入门,如果你有html+css+javascript的基础,那么你就很快地上手掌握的.下面提供微信小程序官方地址:https://developers.weixin.qq.com ...

  3. 微信小程序开发基础知识总结

    微信小程序在无论在功能.文档及相关支持方面,都是优于前面几种微信账号类型,它提供了很多原生程序才有的接口,使得我们的小程序在很多方面突破H5页面应用的限制,更加接近原生程序的功能,因此微信小程序具有很 ...

  4. 微信小程序的配置详解

    1.配置详解: 使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径.窗口表现.设置网络超时时间.设置多 tab 等. 1>pages 接受一个数组,每一项都是字符串,来指定小 ...

  5. 微信小程序开发者工具详解

    一.微信小程序web开发工具下载地址 1.1 在微信公众平台-小程序里边去下载开发工具下载地址. 1.2 下载后安装一下就可以使用了: 二.创建项目 2.1 微信小程序web开发工具需要扫码登陆,所以 ...

  6. 微信小程序wxss样式详解

    一.wxml 界面结构wxmL比较容易理解,主要是由八大类基础组件构成: 一.视图容器(View Container): 二.基础内容(Basic Content) 组件名 说明 组件名 说明 vie ...

  7. 微信小程序 Mustache语法详解

    最近微信小程序非常火,对于前端开发的程序员是个利好的消息,这里主要记录下微信小程序  Mustache语法. 小程序开发的wxml里,用到了Mustache语法.所以,非常有必要把Mustache研究 ...

  8. 微信小程序 生命周期函数详解

    微信小程序 生命周期函数 小程序中 判断当前首页是从其他页面返回,还是由入口打开 由于小程序的数据在我们退出小程序时并没有得到释放,因此再次点击开来数据依然没有变成初始化 解决方法:在小程序 data ...

  9. 微信小程序生命周期详解

    文章出处:https://blog.csdn.net/qq_29712995/article/details/79784222 在我看来小程序的生命周期虽然简单,但是他渗透了小程序开发的整个过程,对于 ...

  10. 微信小程序页面传值详解

    我们知道,在微信小程序中,从一个页面转到另一个页面,一般情况下可以通过navigate或redirect时候的url来携带参数,然后在目标页面的onLoad函数参数中获取这些url参数.例如:   / ...

随机推荐

  1. Go语言学习 _基础03 _数组和切片

    Go语言学习 _基础03 _数组和切片 1.数组 package array_test import "testing" func TestArrayInit(t *testing ...

  2. three.js+vue智慧社区web3d数字孪生三维地图

    案例效果截图如下: 具体案例场景和功能,详见b站视频: https://www.bilibili.com/video/BV1Bb421E7WL/?vd_source=7d4ec9c9275b9c7d1 ...

  3. php几种常用的算法

    1 <?php 2 3 // 选择排序 4 5 function select_sort($arr) 6 7 { 8 9 $count = count($arr); 10 11 for ($i ...

  4. HJ17 坐标移动问题 ——秋招笔试

    HJ17 坐标移动问题 华为笔试[难度中等] 问题描述: 开发一个坐标计算工具, A表示向左移动,D表示向右移动,W表示向上移动,S表示向下移动.从(0,0)点开始移动,从输入字符串里面读取一些坐标, ...

  5. 利用DbgHelp获取线程的栈回溯信息

    当线程发生异常时,我们如果可以记录下来异常线程的堆栈信息,那么对于我们后续问题处理将会有极大的帮助.这里记录一个操作方法. 1 #include <iostream> 2 #include ...

  6. games101_Homework6

    实现 Ray-Bounding Volume 求交与 BVH 查找 在本次编程练习中,你需要实现以下函数: • IntersectP(const Ray& ray, const Vector3 ...

  7. C#/.NET/.NET Core技术前沿周刊 | 第 12 期(2024年11.01-11.10)

    前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录.追踪C#/.NET/.NET Core领域.生态的每周最新.最实用.最有价值的技术文章.社区动态.优质项目和学习资源等. ...

  8. 8.Jenkins+Docker+SpringCloud微服务持续集成

    前言 通过前几章的学习,了解了持续集成概念以及相关技术的学习和使用 接下来学习构建一整套SpringCloud微服务+Docker+Jenkins的持续集成案例 环境 架构图 流程说明: 开发人员将代 ...

  9. 读书笔记-C#8.0本质论-06

    18.4 并行迭代 如果一个对CPU资源占用较大的计算可以很容易被分割为多个彼此完全独立的部分以任意顺序执行,则要使用并行循环.示例如下: using System; using System.Col ...

  10. Mock.js 笔记

    1.介绍 官方文档,Mock.js用来生成随机数据,拦截 Ajax 请求 支持的数据类型丰富,包括文本.数字.布尔值.日期.邮箱.链接.图片.颜色等 功能灵活,生成随机数据 和 拦截 Ajax 请求 ...