小程序简介:
微信小程序,英文名称为Wechat Mini Program,是一种轻量级的应用程序形态,由腾讯公司旗下的微信团队推出。它无需用户通过应用商店下载安装即可在微信内直接使用,实现了“触手可及,用完即走”的用户体验。用户可以通过扫描二维码、搜索关键词或是在微信发现栏目中的小程序入口等方式快速访问相应的小程序。
小程序具有以下特点:
1. **小巧便捷**:相比传统App,小程序体积小,加载速度快,极大地节省了用户的手机存储空间和数据流量。
2. **丰富功能**:小程序涵盖了丰富的功能组件和API接口,能够实现包括消息通知、线下扫码、账号绑定、分享传播、服务切换等基础功能,以及电商购物、生活服务、在线点餐、企业展示、数据分析等多种行业应用场景下的复杂功能。
3. **开发灵活**:开发者可以使用JavaScript、WXML和WXSS等技术进行小程序的定制化开发,满足不同用户群体和业务场景的需求。
4. **易于推广**:依托于微信庞大的用户基数和社交属性,小程序拥有强大的社交传播能力和线上线下联动能力,便于商家和企业推广产品和服务。
自2017年正式上线以来,微信小程序生态得到了迅速发展,吸引了大量的开发者和企业入驻,覆盖了众多行业领域,日活跃用户数以亿计,并且不断创新升级,提供了更强大的功能支持与更好的用户体验。同时,微信官方也持续加强对小程序内容和服务质量的监管,确保其健康发展。
微信小程序优势:
1.无需安装
2.触手可及
3.用完即走
4.无须卸载
微信开发者工具界面功能介绍:
微信开发者工具界面功能主要分为以下几个核心部分:
-
菜单栏:
- 项目:用于创建新的小程序项目,打开已有的项目文件夹,以及管理项目相关的设置和发布操作。
- 文件:进行文件管理,包括新建、保存、关闭文件等操作。
- 编辑:包含编辑代码的功能,如查找替换、格式化代码等。
- 工具:提供辅助开发的工具,例如自动化测试工具、版本控制(如Git)、代码片段管理、性能分析工具等。
- 界面:允许用户自定义显示界面布局,选择显示或隐藏主界面中的各个模块。
- 设置:用于配置开发者工具的各项参数,包括外观样式、快捷键、编辑器选项以及其他个性化设定。
-
工具栏:
- 用户头像区域:点击后可以打开个人中心,实现用户切换、查看消息通知等功能。
- 控制模块显示/隐藏按钮:通过这些按钮可以调整模拟器、编辑器、调试器等模块在主界面中的显示状态。
- 编译与预览按钮:用于编译当前项目的源代码,并在模拟器中实时预览效果,支持普通编译和自定义条件编译。
- 切后台按钮:模拟小程序从前台运行到后台的情况,以便开发者测试不同场景下的行为表现。
- 清缓存按钮:快速清除工具内部及后台授权等相关数据缓存,确保调试环境的清洁。
-
模拟器:
- 模拟器模拟了手机设备的屏幕环境,可以在其中实时展示小程序运行的效果,支持不同尺寸和机型的选择,便于开发者针对多种终端设备做适配性测试。
-
目录树:
- 展示项目文件和资源的层级结构,方便开发者快速定位并打开相应的文件进行编辑。
-
编辑区:
- 提供代码编辑环境,支持WXML、WXSS、JavaScript等小程序所需的各种语言文件的编写和修改。
-
调试器:
- 包含控制台、网络请求监控、存储和性能分析等功能,帮助开发者跟踪代码执行过程,排查错误和优化性能
微信开发者工具常用组合键:
-
文件操作:
Ctrl + S
:保存当前文件。Shift + Ctrl + S
:保存所有文件。Ctrl + N
:新建文件。Ctrl + W
:关闭当前文件。Ctrl + Shift + T
:打开或关闭工具栏。Ctrl + Shift + D
:打开或关闭模拟器。Ctrl + Shift + M
:打开或关闭调试器。
-
代码编辑与导航:
Ctrl + [
,Ctrl + ]
:代码行缩进。Ctrl + Shift + [
,Ctrl + Shift + ]
:折叠或展开代码块。Ctrl + P
或Ctrl + O
:快速打开文件。Ctrl + B
:编译(根据版本和配置可能对应不同功能)。Ctrl + G
:跳转到指定行号的代码。Shift + Alt + F
:格式化代码。
-
预览与刷新:
Ctrl + R
:刷新模拟器中的小程序页面。F5
或者特定的刷新按钮:在某些版本中也可以用于刷新预览。
-
其他操作:
F1
:打开快捷键面板。Ctrl + C
和Ctrl + V
:复制粘贴代码或行,如果未选中文本则复制/粘贴整行。Ctrl + Shift + K
:删除当前行。Ctrl + E
:查看最近打开过的文件列表。
创建我的第一个小程序项目:
// index.js
const defaultAvatarUrl = 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0'
Page({
data: {
motto: 'Hello World',
userInfo: {
avatarUrl: defaultAvatarUrl,
nickName: '',
},
hasUserInfo: false,
canIUseGetUserProfile: wx.canIUse('getUserProfile'),
canIUseNicknameComp: wx.canIUse('input.type.nickname'),
},
bindViewTap() {
wx.navigateTo({
url: '../logs/logs'
})
},
onChooseAvatar(e) {
const { avatarUrl } = e.detail
const { nickName } = this.data.userInfo
this.setData({
"userInfo.avatarUrl": avatarUrl,
hasUserInfo: nickName && avatarUrl && avatarUrl !== defaultAvatarUrl,
})
},
onInputChange(e) {
const nickName = e.detail.value
const { avatarUrl } = this.data.userInfo
this.setData({
"userInfo.nickName": nickName,
hasUserInfo: nickName && avatarUrl && avatarUrl !== defaultAvatarUrl,
})
},
getUserProfile(e) {
// 推荐使用wx.getUserProfile获取用户信息,开发者每次通过该接口获取用户个人信息均需用户确认,开发者妥善保管用户快速填写的头像昵称,避免重复弹窗
wx.getUserProfile({
desc: '展示用户信息', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
success: (res) => {
console.log(res)
this.setData({
userInfo: res.userInfo,
hasUserInfo: true
})
}
})
},
})
//index.json:
{
"usingComponents": {
}
}
<!--index.wxml-->
<scroll-view class="scrollarea" scroll-y type="list">
<view class="container">
<view class="userinfo">
<block wx:if="{{canIUseNicknameComp && !hasUserInfo}}">
<button class="avatar-wrapper" open-type="chooseAvatar" bind:chooseavatar="onChooseAvatar">
<image class="avatar" src="{{userInfo.avatarUrl}}"></image>
</button>
<view class="nickname-wrapper">
<text class="nickname-label">昵称</text>
<input type="nickname" class="nickname-input" placeholder="请输入昵称" bind:change="onInputChange" />
</view>
</block>
<block wx:elif="{{!hasUserInfo}}">
<button wx:if="{{canIUseGetUserProfile}}" bindtap="getUserProfile"> 获取头像昵称 </button>
<view wx:else> 请使用2.10.4及以上版本基础库 </view>
</block>
<block wx:else>
<image bindtap="bindViewTap" class="userinfo-avatar" src="{{userInfo.avatarUrl}}" mode="cover"></image>
<text class="userinfo-nickname">{{userInfo.nickName}}</text>
</block>
</view>
<view class="usermotto">
<text class="user-motto">{{motto}}</text>
</view>
</view>
</scroll-view>
/**index.wxss**/
page {
height: 100vh;
display: flex;
flex-direction: column;
}
.scrollarea {
flex: 1;
overflow-y: hidden;
}
.userinfo {
display: flex;
flex-direction: column;
align-items: center;
color: #aaa;
width: 80%;
}
.userinfo-avatar {
overflow: hidden;
width: 128rpx;
height: 128rpx;
margin: 20rpx;
border-radius: 50%;
}
.usermotto {
margin-top: 200px;
}
.avatar-wrapper {
padding: 0;
width: 56px !important;
border-radius: 8px;
margin-top: 40px;
margin-bottom: 40px;
}
.avatar {
display: block;
width: 56px;
height: 56px;
}
.nickname-wrapper {
display: flex;
width: 100%;
padding: 16px;
box-sizing: border-box;
border-top: .5px solid rgba(0, 0, 0, 0.1);
border-bottom: .5px solid rgba(0, 0, 0, 0.1);
color: black;
}
.nickname-label {
width: 105px;
}
.nickname-input {
flex: 1;
}
运行结果: