零基础学微信小程序前端(原生JS):从0到1写第一个可交互页面

零基础学微信小程序前端(原生JS):从0到1写第一个可交互页面

目录

一、小程序前端的核心差异

二、前期准备:微信开发者工具搭建

三、核心知识点:小程序前端的目录结构

四、实操:写第一个可交互页面

1. 编写页面结构(index.wxml)

2. 编写页面样式(index.wxss)

3. 编写页面逻辑(index.js)

五、运行测试:看看效果

六、新手常见问题&解决方法

七、入门总结


一、小程序前端的核心差异

和你熟悉的 Web 前端(HTML+CSS+JS)相比,小程序有 3 个核心不同:

  1. 标签不同:HTML 的div/p/span → 小程序的view/textbutton等组件是微信封装好的;
  2. 单位不同:Web 的px → 小程序的rpx(自适应不同屏幕,1rpx = 屏幕宽度 / 750);
  3. 运行环境不同:小程序运行在微信内置的渲染引擎,而非浏览器,所以没有window/document等 DOM API,而是用微信提供的wx.xxx API(如wx.showToast)。

二、前期准备:微信开发者工具搭建

工欲善其事,必先利其器。小程序前端开发最核心的工具就是微信开发者工具,步骤很简单,跟着官方指引来就好。

1. 下载安装:直接去微信公众平台开发者工具页面,下载对应自己系统(Windows/Mac)的版本,一路下一步安装即可,没有复杂配置。

2. 新建测试项目:打开开发者工具,登录自己的微信账号(必须登录,否则无法创建项目),然后点击「+新建项目」,按照提示填写:

  • 项目名称:随便填,我填的是「mini-frontend-demo」(小程序前端demo);
  • 项目路径:选择自己电脑上的一个空文件夹,方便后续管理;
  • AppID:因为是新手,还没有注册小程序账号,直接选择「测试号」即可(测试号足够我们本地开发和测试,无需审核);
  • 其他选项:取消勾选「云服务」(暂时用不到),点击「创建」。

3. 熟悉工具界面:创建成功后,会自动进入开发者工具界面,主要分为三个部分(新手重点关注):

  • 模拟器:实时显示小程序的运行效果,和手机上看到的一致;
  • 编辑器:编写代码的地方,默认会生成一个基础模板;
  • 调试器:类似浏览器的控制台,用来打印日志、排查错误,非常重要。

三、核心知识点:小程序前端的目录结构

刚创建好项目,看到一堆文件可能会懵,其实小程序的目录结构很清晰,核心就两类文件:全局文件和页面文件,新手先记住这几个核心文件即可,不用纠结其他自动生成的文件。

默认项目目录如下(重点标注核心文件):

重点说明3个核心文件的作用:

  1. index.wxml:页面结构,相当于Web的HTML,但不能用div、p、span这些标签,只能用小程序官方提供的组件,比如view(类似div)、text(类似span)、button(按钮)等;
  2. index.wxss:页面样式,相当于Web的CSS,但有一个关键区别——单位用rpx(自适应单位),而不是px,rpx能自动适配不同尺寸的手机屏幕,1rpx = 屏幕宽度/750,不用自己做适配;
  3. index.js:页面逻辑,用原生JS编写,但不能用window、document等DOM API,小程序提供了专属的wx.xxx API(比如弹窗、跳转),所有页面逻辑都要包裹在Page({})里。

注意!标签的替换

四、实操:写第一个可交互页面

接下来就是最核心的部分,从零编写一个可交互的页面,目标很简单:显示一段初始文本,有一个按钮,点击按钮可以修改文本,还有一个输入框,能实时获取输入内容,点击按钮时一并显示输入的内容。

全程分三步:编写页面结构(wxml)→ 编写页面样式(wxss)→ 编写页面逻辑(js),每一步都贴完整代码,加详细注释,方便大家复制实操。

1. 编写页面结构(index.wxml)

替换pages/index/index.wxml里的默认内容,代码如下(每一行都加了注释,新手能看懂):

<!-- 容器视图,类似Web的div,用来包裹所有内容 --> <view> <!-- 文本组件,{{msg}}是数据绑定,取值来自index.js里的data.msg --> <text>{{msg}}</text> <!-- 输入框组件,bindinput绑定输入事件,实时获取输入内容 --> <input placeholder="请输入内容(可选)" bindinput="inputHandler" value="{{inputValue}}" /> <!-- 按钮组件,bindtap绑定点击事件(事件名是clickHandler,后续在js里定义) --> <button bindtap="clickHandler">点击修改文本</button> </view>

这里的核心是「数据绑定」,用{{变量名}}的方式,把js里的数据渲染到页面上,后续我们修改js里的变量,页面就会同步更新。

2. 编写页面样式(index.wxss)

替换pages/index/index.wxss里的默认内容,重点用rpx单位,样式尽量简单,贴合新手水平:

/* 页面容器:设置内边距、居中对齐,flex布局方便垂直排列 */ .page-container { padding: 30rpx; display: flex; flex-direction: column; align-items: center; /* 水平居中 */ } /* 文本样式:设置字体大小、颜色,margin-bottom控制与按钮的间距 */ .content-text { font-size: 36rpx; /* 推荐用rpx,自适应屏幕 */ color: #333; /* 深灰色,比纯黑更柔和 */ margin-bottom: 40rpx; /* 与按钮的间距 */ } /* 按钮样式:设置宽高、背景色、圆角,让按钮更美观 */ .operate-btn { width: 600rpx; height: 80rpx; line-height: 50rpx; /* 让文字垂直居中 */ background-color: #07c160; /* 微信绿,贴合小程序风格 */ color: #fff; /* 白色文字 */ border-radius: 40rpx; /* 圆角,更圆润 */ margin-bottom: 30rpx; /* 与输入框的间距 */ } /* 输入框样式:设置边框、内边距,避免太单调 */ .input-box { width: 600rpx; height: 80rpx; border: 1rpx solid #eee; /* 浅灰色边框 */ padding: 0 20rpx; /* 左右内边距,避免文字贴边 */ border-radius: 40rpx; font-size: 32rpx; }

样式这里没什么复杂的,都是基础的CSS属性,重点记住「不用px用rpx」,还有小程序的样式不支持*通配符,刚开始我试了用*重置样式,结果没生效,后来查了资料才知道这个限制。

3. 编写页面逻辑(index.js)

这是最核心的部分,替换pages/index/index.js里的默认内容,代码如下,注释详细,重点讲解数据绑定和事件处理:

// Page()是小程序页面的核心函数,所有页面逻辑都必须包裹在这个函数里 Page({ // 1. 页面初始数据:所有要渲染到页面的变量都存放在这里 // 相当于Web里的data,通过{{变量名}}绑定到wxml页面 data: { msg: "Hello 微信小程序!", // 初始文本,会显示在页面上 inputValue: "" // 输入框的初始值,为空 }, // 2. 按钮点击事件处理函数(对应wxml里的bindtap="clickHandler") // 函数名必须和bindtap的值完全一致,注意大小写 clickHandler() { // ① 弹出成功提示(小程序内置API,wx.showToast) wx.showToast({ title: '点击成功!', // 提示文本 icon: 'success', // 提示图标(success是绿色对勾,loading是加载中,none是无图标) duration: 1500 // 提示显示时长,单位是毫秒 }); // ② 修改页面数据:重点!必须用this.setData(),不能直接this.data.msg = xxx // 直接修改this.data不会更新页面视图,只有setData才能触发页面重新渲染 this.setData({ msg: "你点击了按钮!输入的内容是:" + this.data.inputValue }); }, // 3. 输入框输入事件处理函数(对应wxml里的bindinput="inputHandler") // 实时获取输入框的内容,更新到data里的inputValue inputHandler(e) { // e是事件对象,e.detail.value是小程序输入框获取值的固定方式 this.setData({ inputValue: e.detail.value }); }, // 4. 页面生命周期函数:页面加载时自动执行(不用手动调用) // 可以在这里做一些初始化操作,比如请求后端数据 onLoad(options) { console.log("首页加载完成!"); // 在调试器的Console里可以看到这条日志 } });

这里有两个重点:

  • 修改页面数据必须用this.setData(),不能直接赋值(比如this.data.msg = "新文本",这样页面不会更新);
  • 事件绑定的函数名必须和wxml里bindtap的值完全一致,大小写敏感,比如我刚开始把clickHandler写成了clickhandler,点击按钮没反应,排查了好久才发现是大小写错了。

五、运行测试:看看效果

写完代码后,点击开发者工具右上角的圈箭头按钮,模拟器里就会显示我们写的页面,效果如下:

  1. 初始状态:显示「Hello 微信小程序!」,下方是输入框,最下方有一个绿色按钮;
  2. 输入测试:在输入框里输入「这是tt测试」;
  3. 点击按钮:弹出的「点击成功!」提示,同时页面上的文本变成「你点击了按钮!输入的内容是:这是tt测试」;
  4. 调试日志:打开调试器的「Console」面板,能看到「首页加载完成!」的日志,方便我们排查错误。

到这里,我们的第一个可交互的小程序页面就完成了!是不是很有成就感?作为零基础新手,能写出这样一个简单的页面,已经迈出了一大步。

六、新手常见问题&解决方法

在实操过程中,我遇到了几个新手常犯的错误,整理出来,帮大家避坑:

问题现象

问题原因

解决方法

页面白屏,调试器报「page not found」

新增页面后,没有在app.json的pages数组里注册

在app.json的pages数组里添加页面路径,比如["pages/index/index"],顺序越靠前,默认显示哪个页面

点击按钮没反应,调试器没报错

事件绑定函数名写错(大小写不一致),或bindtap写成了bindTap

检查wxml里的bindtap值和js里的函数名完全一致,严格区分大小写

修改data后,页面不更新

直接修改this.data.xxx,没有调用this.setData()

必须用this.setData({ xxx: 新值 })修改数据,才能触发页面重新渲染

样式不生效

使用了*通配符,或样式选择器和wxml里的class名不一致

去掉*通配符,检查选择器和wxml里的class名完全一致

输入框无法获取输入内容

没有绑定bindinput事件,或没有用e.detail.value取值

给input标签添加bindinput事件,在事件处理函数里用e.detail.value获取输入值

七、入门总结

通过这次实操,我终于搞懂了小程序前端的基础逻辑,总结一下核心知识点:

小程序前端核心:wxml(结构)+ wxss(样式)+ js(逻辑),和Web前端类似,但有专属的标签、单位和API;核心技能:数据绑定({{变量名}})、事件绑定(bindtap)、setData修改数据;新手避坑:不用HTML标签、不用px单位、修改数据用setData、事件名大小写一致。 

Read more

实验三 Windows Server 2022/2025 搭建 Web 服务器实验指导书

实验三 Windows Server 2022/2025 搭建 Web 服务器实验指导书

作者:非凡大爹|版本:v1|日期:2026-03-30|DocID:CN-LAB-2026-03-WEB-1-LG-V1 原创声明:本文为非凡大爹原创,首发于ZEEKLOG,转载或引用请注明出处。 一、实验基本信息 课程名称: Windows 网络管理 / 网络操作系统 / 服务器配置与管理 实验名称: Windows Server 2022/2025 搭建 Web 服务器 实验性质: 验证性 + 应用性实验 实验类别: 综合配置实验 建议学时: 2 学时 实验方式: 学生独立操作 + 结果验证 二、实验目的 1. 知识目标 理解 Web 服务器的基本作用,了解网站从“本地网页文件”到“网络可访问服务”的基本发布过程,

前端状态管理比较:选择适合你的状态管理方案

前端状态管理比较:选择适合你的状态管理方案 毒舌时刻 状态管理?听起来就像是前端工程师为了显得自己很高级而特意发明的复杂概念。你以为随便找个状态管理库就能解决所有问题?别做梦了!到时候你会发现,状态管理库本身就是个问题。 你以为Redux是万能的?别天真了!Redux的样板代码多到让你崩溃,调试起来也非常麻烦。还有那些所谓的轻量级状态管理库,看起来简单,用起来却各种问题。 为什么你需要这个 1. 复杂状态管理:当应用变得复杂时,组件间的状态共享和管理会变得非常困难,需要一个专门的状态管理方案。 2. 可预测性:良好的状态管理方案可以让状态变化变得可预测,便于调试和测试。 3. 性能优化:状态管理方案可以帮助你优化组件渲染,提高应用性能。 4. 代码组织:状态管理方案可以帮助你更好地组织代码,提高代码的可维护性。 5. 团队协作:统一的状态管理方案可以便于团队成员之间的协作,减少沟通成本。 反面教材 // 这是一个典型的状态管理混乱的例子 import React, { useState, useEffect } from 'react'; function

前端真的能防录屏?EME(加密媒体扩展) DRM 反录屏原理 + 实战代码

前端真的能防录屏?EME(加密媒体扩展) DRM 反录屏原理 + 实战代码

🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志 🎐 个人CSND主页——Micro麦可乐的博客 🐥《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程,入门到实战 🌺《RabbitMQ》专栏19年编写主要介绍使用JAVA开发RabbitMQ的系列教程,从基础知识到项目实战 🌸《设计模式》专栏以实际的生活场景为案例进行讲解,让大家对设计模式有一个更清晰的理解 🌛《开源项目》本专栏主要介绍目前热门的开源项目,带大家快速了解并轻松上手使用 🍎 《前端技术》专栏以实战为主介绍日常开发中前端应用的一些功能以及技巧,均附有完整的代码示例 ✨《开发技巧》本专栏包含了各种系统的设计原理以及注意事项,并分享一些日常开发的功能小技巧 💕《Jenkins实战》专栏主要介绍Jenkins+Docker的实战教程,让你快速掌握项目CI/CD,是2024年最新的实战教程 🌞《Spring Boot》专栏主要介绍我们日常工作项目中经常应用到的功能以及技巧,代码样例完整 👍《Spring Security》专栏中我们将逐步深入Spring Security的各个

树莓派5部署冬瓜HAOS:从零到智能家居中枢实战

1. 准备工作:硬件与软件选择 在开始部署冬瓜HAOS之前,选择合适的硬件和软件是确保系统稳定运行的关键。树莓派5作为最新的单板计算机,性能比前代提升显著,尤其适合作为智能家居中枢。我实测下来,树莓派5的多核处理能力和更高的内存带宽(支持8GB LPDDR4X)能够轻松应对Home Assistant的多任务需求,比如同时处理传感器数据、摄像头流媒体和自动化规则。 硬件方面,除了树莓派5主板,你需要准备以下配件: * TF卡:推荐使用SanDisk Extreme PRO系列(64GB以上,U3 A2 V30规格)。这种高速卡能显著提升系统响应速度,因为HAOS会频繁读写日志和数据库。我试过用普通Class 10卡,启动时间长了近一倍,偶尔还会卡顿。 * 电源适配器:树莓派5需要27W USB-C PD电源(官方电源最稳)。我用过第三方电源,偶尔会触发低压警告,导致系统不稳定。 * 散热方案:树莓派5运行时CPU温度可能飙到70°C以上,建议加装散热风扇或金属散热片。我用的是一体化散热外壳,待机温度控制在40°C左右。 * 外设:HDMI显示器、