微信小程序核心知识点速览

微信小程序凭借轻量、即用即走的特性,成为移动开发的重要选择。本文梳理几个核心知识点,助你快速入门。

1. 项目结构:清晰的文件规范

小程序有固定的文件结构,核心包括:

  • .json:配置文件(如页面路径、窗口表现)
  • .wxml:模板文件(类似 HTML,定义页面结构)
  • .wxss:样式文件(类似 CSS,支持 rpx 自适应单位)
  • .js:逻辑脚本(处理数据和交互)

全局配置在app.json中定义,页面配置在各自目录的.json中,可覆盖全局设置。

2. 数据绑定与渲染:声明式开发

小程序采用数据驱动视图,通过{``{ }}绑定数据:

复制代码
<!-- 页面.wxml -->
<view>{{ message }}</view>
<text wx:if="{{ isShow }}">条件渲染</text>
<view wx:for="{{ list }}" wx:key="index">
  {{ index }}: {{ item.name }}
</view>

// 页面.js
Page({
  data: {
    message: "Hello 小程序",
    isShow: true,
    list: [{ name: "商品1" }, { name: "商品2" }]
  }
})

修改数据需用this.setData({ ... }),小程序会自动更新视图。

3. 事件处理:交互的核心

通过bindtap等指令绑定事件,处理用户交互:

复制代码
<button bindtap="handleClick">点击我</button>

Page({
  handleClick() {
    wx.showToast({ title: "点击成功" });
  }
})

事件传参需用data-*属性:

复制代码
<button bindtap="deleteItem" data-id="1">删除</button>

deleteItem(e) {
  const id = e.currentTarget.dataset.id; // 获取参数
}

4. 页面路由:页面跳转与传参

小程序通过wx.navigateTo等 API 实现页面跳转:

复制代码
// 跳转到新页面(保留当前页)
wx.navigateTo({
  url: '/pages/detail/detail?id=1'
})

// 关闭当前页,跳转到目标页
wx.redirectTo({ url: '/pages/home/home' })

目标页面在onLoad中接收参数:

复制代码
Page({
  onLoad(options) {
    console.log(options.id); // 获取跳转携带的id
  }
})

5. 生命周期:页面的 "一生"

页面生命周期函数控制页面状态:

  • onLoad:页面加载时触发(只执行一次)
  • onShow:页面显示时触发(每次切换到该页都执行)
  • onReady:页面初次渲染完成时触发
  • onUnload:页面卸载时触发(如跳转并关闭当前页)

合理利用生命周期,可实现数据初始化、资源释放等操作。

6. API 能力:丰富的原生接口

小程序提供大量 API,覆盖设备、网络、支付等场景:

  • 网络请求:wx.request(需配置合法域名)
  • 本地存储:wx.setStorageSync/wx.getStorageSync
  • 设备信息:wx.getSystemInfoSync
  • 交互反馈:wx.showToast/wx.showModal

示例:发起网络请求

复制代码
wx.request({
  url: 'https://api.example.com/data',
  method: 'GET',
  success(res) {
    console.log(res.data);
  }
})

总结

小程序开发的核心是遵循其框架规范,利用数据绑定、组件化(自定义组件)、API 能力快速构建应用。掌握上述知识点后,可进一步学习自定义组件、分包加载、性能优化等进阶内容,打造更优质的小程序体验。

相关推荐
2501_916008894 小时前
Web 前端开发常用工具推荐与团队实践分享
android·前端·ios·小程序·uni-app·iphone·webview
2501_915921434 小时前
“HTTPS 个人化”实战,个人站点与设备调试的部署、验证与抓包排查方法
网络协议·http·ios·小程序·https·uni-app·iphone
菜鸟una5 小时前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
韩立学长6 小时前
【开题答辩实录分享】以《租房小程序的设计和实现》为例进行答辩实录分享
java·spring boot·小程序
從南走到北6 小时前
JAVA国际版一对一视频交友视频聊天系统源码支持H5 + APP
java·微信·微信小程序·小程序·音视频·交友
future_studio7 小时前
聊聊 Unity(小白专享、C# 小程序 之 联机对战)
unity·小程序·c#
隔壁程序员老王7 小时前
基于 Python 的坦克大战小程序,使用 Pygame 库开发
python·小程序·pygame·1024程序员节
從南走到北7 小时前
同城派送小程序
微信·微信小程序·小程序
腾讯云云开发9 小时前
3小时上线!云开发“零运维”外卖小程序指南
微信小程序·ai编程·小程序·云开发
腾讯云云开发9 小时前
云开发1天极速开店!1人搞定全流程
微信小程序·ai编程·小程序·云开发