微信小程序的学习(一)
一、小程序简介
1、小程序与普通网页开发的区别
运行环境不同
- 网页运行在浏览器环境中
- 小程序运行在微信环境中
API不同
- 小程序无法调用浏览器中的DOM和BOM的API
- 但是小程序可以调用微信环境提供的各种API,地理定位、扫码、支付等等
开发模式不同
- 网页的开发模式:浏览器 + 代码编辑器
- 小程序的标准开发模式
- 申请小程序开发账号
- 安装小程序开发者工具
- 创建和配置小程序项目
2、注册小程序账号
- 打开 https:// mp.weixin.qq.com/ 网址,点击立即注册按钮,选择小程序,按照步骤进行注册
- 获取小程序的 AppID(创建小程序项目的时候需要用到)
3、安装开发者工具
3.1、开发者工具的功能:
快速创建小程序项目
代码的查看和编辑
对小程序功能进行调试
小程序的预览和发布
3.2、下载 稳定版 的开发者工具
- 打开 首页 | 微信开放社区 (qq.com) 网址,点击文档 之后,按照下面的步骤进去下载页面
- 选择稳定版的下载链接进行下载
3. 找到下载的安装包,打开直接安装就好啦!
3.3、设置外观和代理
- 点击设置,按自己的爱好设置外观
- 为了方便学习,代理哪里勾选第一个:不使用任何代理
二、小程序起步
1、创建小程序项目
- 点击 “ + ” 号
- 填写相关信息
3. 出现以下页面即为成功!
4. 查看项目效果的两个方法:①:用模拟器;②:用真机;
2、认识小程序项目的基本组成结构
2.1、了解项目的基本组成结构
2.2、小程序页面的组成部分
2.3、改变小程序窗口背景色:navigationBarBackgroundColor
3、新建小程序页面
3.1、新建小程序页面
只需要在app.json -> pages中新增页面的存放路径,小程序开发者工具即可帮我们自动创建对应的页面文件,如图所示:
3.2、修改小程序首页
只需要调整app.json -> pages数组中页面路径的前后顺序,即可修改项目的首页。小程序会把排在第一-位的页面,当作项目首页进行渲染,如图所示:
4、WXML(Weixin Markup Language)模板
4.1、简介:WXML 是小程序框架设计的一套标签语言,用来构建小程序页面的结构,其作用类似于网页开发中的HTML
4.2、WXML与HTML的区别
- 标签名称不同
HTML(div,span,img,a)
WXML(view,text,image,navigator)
- 属性节点不同
<a href="#">超链接</a>
- <navigator url=" /pages/home/home"></ navigator>
- 提供了类似于Vue中的模板语法
- 数据绑定
- 列表渲染
- 条件渲染
5、WXSS(WeiXin Style Sheets)样式
5.1、简介:WXSS 是一套样式语言,用于描述WXML的组件样式,类似于网页开发中的CSS。
5.2、WXSS与css的区别
- 新增了rpx尺寸单位
css中需要手动进行像素单位换算,例如rem
wxss在底层支持新的尺寸单位rpx,在不同大小屏幕上小程序会自动进行换算
- 提供了全局的样式和局部样式
项目根目录中的app.wxss会作用于所有小程序页面
局部页面的.wxss 样式仅对当前页面生效
- wxss 仅支持部分css 选择器
.class 和 #id
element
并集选择器、后代选择器
::after 和 ::before 等伪类选择器
6、JS 逻辑交互
6.1、小程序中的 .js 文件
一个项目仅仅提供界面展示是不够的,在小程序中,我们通过js文件来处理用户的操作。例如:响应用户的点击、获取用户的位置等等
6.2、小程序中 .js 文件的分类
app.js :是整个小程序项目的人口文件,通过调用 App() 函数来启动整个小程序
页面的 .js文件:是页面的人口文件,通过调用 Page() 函数来创建并运行页面
普通的 .js 文件:是普通的功能模块文件,用来封装公共的函数或属性供页面使用
7、小程序的宿主环境(host environment)
7.1、宿主环境指的是:程序运行所必须的依赖环境。
7.2 举个栗子:Android系统和ios系统是两个不同的宿主环境
注意:脱离了宿主环境的软件是没有任何意义的!
7.3、手机微信是小程序的宿主环境
小程序借助宿主环境提供的能力,可以完成许多普通网页无法完成的功能,例如:微信扫码、微信支付、微信查录、地理定位、etc...
7.4、小程序宿主环境包含的内容
通信模型
运行机制
组件
API
8、通信模型
8.1、通信的主体
小程序中通信的主体是渲染层和逻辑层
WXML 模板和 wxss 样式工作在渲染层
JS 脚本工作在逻辑层
8.2、小程序的通信模型
小程序中的通信模型分为两部分:
渲染层和逻辑层之间的通信
- 由微信客户端进行转发
逻辑层和第三方服务器之间的通信
由微信客户端进行转发
如图所示:
9、小程序的运行机制
9.1、小程序的启动过程
把小程序的代码包下载到本地
解析 app.json 全局配置文件
执行 app.js 小程序人口文件,调用 App() 创建小程序实例
渲染小程序首页
小程序启动完成
9.2、页面渲染的过程
加载解析页面的 .json 配置文件
加载页面的 .wxml 模板和 .wxss 样式
执行页面的 .js 文件,调用 Page() 创建页面实例
页面渲染完成
10、组件
10.1、组件的分类
视图容器
- view
- 普通视图区域
- 类似于 HTML 中的 div,是一个块级元素
- 常用于实现页面的布局效果
- scroll-view
- 可滚动的视图区域
- 常用于实现滚动列表效果
- swiper 和 swiper-item
- 轮播容器组件 和 轮播图 item 组件
基础内容
- text
- 文本组件
- 类似于 HTML 中的 span 标签,是一个行内元素
- rich-text
- 富文本组件
- 支持把 HTML 字符串渲染为 WXML 结构
其他常用组件
- navigator
- 页面导航组件
- 类似于 HTML 中的超链接
- image
- 图片组件
- image 组件默认宽度为 300px、高度为 240px
- button
- 按钮组件
- 功能比 HTML 中的 button 按钮丰富
- 通过 open-type 属性可以调用微信提供的各种功能(客服、转发、获取用户授权、获取用户信息等)
- navigator
表单组件
导航组件
媒体组件
map 地图组件
canvas 画布组件
开放能力
无障碍访问
10.2、viem 组件的基本使用
需求:实现如图的flex(弹性布局)效果
- wxml 代码
<!-- html代码 -->
<view class="big">
<view>A</view>
<view>B</view>
<view>C</view>
</view>
- wxss 代码
/* wxss代码 */
.big{
display: flex;
justify-content: space-around;
} .big view{
width: 100px;
height: 100px;
text-align: center;
line-height: 100px;
}
.big view:nth-child(1){
background-color: lightgreen;
}
.big view:nth-child(2){
background-color: lightseagreen;
}
.big view:nth-child(3){
background-color: pink;
}
10.3、scroll-view 组件的基本使用
需求:实现如下图的纵向滚动效果
- wxml 代码
<!-- scroll-x:允许横向滚动 -->
<!-- scroll-y:允许纵向滚动 --> <scroll-view class="big2" scroll-y>
<view>A</view>
<view>B</view>
<view>C</view>
</scroll-view>
- wxss 代码
.big2{
width: 100px;
height: 220px;
/* border: 1px solid red; */
} .big2 view{
width: 100px;
height: 100px;
text-align: center;
line-height: 100px;
}
.big2 view:nth-child(1){
background-color: lightgreen;
}
.big2 view:nth-child(2){
background-color: lightseagreen;
}
.big2 view:nth-child(3){
background-color: pink;
}
10.4、swiper 和 swiper-item 组件的基本使用
需求:实现如下轮播图的效果
- wxml 代码
<!-- swiper与swiper-item组件的基本使用 -->
<!-- indicator-dots:显示面板指示点 -->
<!-- 轮播图容器 -->
<swiper class="big3" indicator-dots>
<!-- 第一项轮播图 -->
<swiper-item>
<view class="item">A</view>
</swiper-item>
<!-- 第二项轮播图 -->
<swiper-item>
<view class="item">B</view>
</swiper-item>
<!-- 第三项轮播图 -->
<swiper-item>
<view class="item">C</view>
</swiper-item>
</swiper>
- wxss 代码
/* swiper与swiper-item组件的基本使用 */
.big3{
height: 150px;
}
.item{
height: 100%;
text-align: center;
line-height: 150px;
}
swiper-item:nth-child(1) .item{
background-color: lightgreen;
}
swiper-item:nth-child(2) .item{
background-color: lightseagreen;
}
swiper-item:nth-child(3) .item{
background-color: pink;
}
- swiper 组件的常用属性
10.5、text 组件的基本使用
需求:通过 text 组件的 selectable 属性,实现长按选中文本内容(例如实现复制功能)的效果:
- wxml 代码
<!-- text组件的基本使用 -->
<view class="big4">
长按手机号复制文本内容:<text selectable>13800005056</text>
</view>
10.6、rich-text 组件的基本使用
需求:通过 rich-text 组件的nodes属性节点,把HTML字符串渲染为对应的UI结构:
10.7、button 按钮的基本使用
10.8、image 组件的基本使用
image组件的mode属性用来指定图片的裁剪和缩放模式,常用的mode属性值如下:
11、API
11.1、概述
小程序中的API是由宿主环境提供的,通过这些丰自的小程序API,开发者可以方使的阔用微信提供的能力;
例如:获取用户信息、本地存储、支付功能等
11.2、API 的分类
- 事件监听API
特点:以 on 开头,用来监听某些事件的触发
举例::wx.onWindowResize(function callback)监听窗口尺寸变化的事件
- 同步 API
特点1:以 Sync 结尾的API都是同步API
特点2:同步API的执行结果,可以通过函数返回值直接获取,如果执行出错会抛出异常
举例:wx.setStorageSync('key', 'value')向本地存储中写入内容
- 异步 API
特点:类似于 jQuery 中的 $.ajax(options)函数,需要通过success、fail、 complete 接收调用的结果
举例:wx.request() 发起网络数据请求,通过success回调函数接收数据
12、协同工作
12.1、了解权限管理需求
在中大型的公司里,人员的分工非常仔细:同一个小程序项目,一般会有不同岗位、不同角色的员工同时参与设计与开发。此时出于管理需要,我们迫切需要对不同岗位、不同角色的员工的权限进行边界的划分,使他们能够高效的进行协同工作。
12.2、了解项目人员的组织结构,如图所示:
12.3、小程序的开发流程
12.4、成员管理
12.5、不同成员对应的权限
微信小程序的学习(一)的更多相关文章
- 微信小程序js学习心得体会
微信小程序js学习心得体会 页面控制的bindtap和catchtap 用法,区别 <button id='123' data-userDate='100' bindtap='tabMessag ...
- 微信小程序入门学习
前(che)言(dan): 近几天,微信小程序的内测引起了众多开发人员的热议,很多人都认为这将会成为一大热门,那么好吧,虽然我是一个小白,但这是个新玩意,花点时间稍稍钻研一下也是无妨的,谁让我没有女朋 ...
- 微信小程序开发学习资料
作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...
- 微信小程序入门学习-- 简易Demo:计算器
简单学习下微信小程序 官网 简易教程 · 小程序 https://mp.weixin.qq.com/debug/wxadoc/dev/ 需要通过开发者工具,来完成小程序创建和代码编辑. 下载安装,运行 ...
- 微信小程序组件学习 -- 注册页面
微信小程序组件使用手册地址: 1. 百度搜索"微信公众平台",扫码登录之后,点击帮助文档里面的普通小程序. 2. 接着选择"开发"-->"组件& ...
- 微信小程序开发学习(一):开发前准备
开发前准备 Step1:注册 微信小程序开放平台: https://mp.weixin.qq.com/cgi-bin/wx 开发者注册: https://mp.weixin.qq.com/wxopen ...
- 第1-5章 慕课网微信小程序开发学习笔记
第1章 前言:不同的时代,不同的Web --微信小程序商城构建全栈应用 http://note.youdao.com/noteshare?id=a0e9b058853dbccf886c1a890594 ...
- 微信小程序开发学习记录
两天撸了一遍小程序的文档,跟网页相似,个人感觉是简化版.但是因为开放了很多微信自带的接口又使得部分功能开发起来相对方便 思维导图如下: 目前我的理解大概是这么个逻辑,以后深入学习后可能会有更改 跟着大 ...
- 微信小程序入门学习之事件 事件对象 冒泡非冒泡事件(1)
这关于事件的学习,可以自己复制到微信开发者工具上自己运行试试. 首先这里有两个文件.js 和.wxml 文件 首先给出.js文件下代码 // pages/news/news.js Page({ /** ...
- 微信小程序开发学习(二)
一些官方API 总结了一些官方API,便于之后有用时针对性查找(发现官方给了好多好用的API)官方API文档 基础 wx.canIUse:判断小程序的API,回调,参数,组件等是否在当前版本可用,返回 ...
随机推荐
- grub2配置文件丢失如何修复
实验操作准备 此步骤因实验需要所做,系统开机属grub界面无需此步! lsblk命令为了查看根分区挂载在什么位置 rm -rf /boot/grub2/grub.cfg命令为删除grub2配置文件到达 ...
- KingbaseES V8R6C5禁用root用户ssh登录图形化部署集群案例
案例说明: 对于KingbaseES V8R6C5版本在部集群时,需要建立kingbase.root用户在节点间的ssh互信,如果在生产环境禁用root用户ssh登录,则通过ssh部署会失败:在图形化 ...
- docker-compose部署elastiflow
docker-compose导入导出命令 涉及的命令有export.import.save.load save 命令 docker save [options] images [images...] ...
- 新增一个Redis 从节点为什么与主节点的key数量不一样呢?
在日常的 Redis 运维过程中,经常会发生重载 RDB 文件操作,主要情形有: 主从架构如果主库宕机做高可用切换,原从库会挂载新主库重新获取数据 主库 QPS 超过10万,需要做读写分离,重新添加从 ...
- Svelte Ui Admin后台管理系统|svelte3+svelteUI中后台前端解决方案
基于svelte3.x+svelteKit+svelte-ui网页后台管理系统SvelteAdmin. Svelte-Ui-Admin 基于svelte3.x+svelteKit+vite3+echa ...
- 4、StringBuilder类
StringBuilder类 一个可变的字符序列,此类提供一个与StringBuffer 兼容的 API,但不保证同步(StringBuilder 不是线程安全). 该类被设计用作 StringBuf ...
- Pod原理
Pod 是 Kubernetes 集群中最基本的调度单元,我们平时在集群中部署的应用都是以 Pod 为单位的,而并不是我们熟知的容器,这样设计的目的是什么呢?为何不直接使用容器呢? 为什么需要 Pod ...
- Elasticsearch 主从同步之跨集群复制
文章转载自:https://mp.weixin.qq.com/s/alHHxXont6XFm_m9PfsGfw 1.什么是跨集群复制? 跨集群复制(Cross-cluster replication, ...
- k8s更换网络插件:从flannel更换成calico
卸载flannel 查看已安装的flannel的信息 # 查看CNI插件,可以得知使用的是flannel # cat /etc/cni/net.d/10-flannel.conflist { &quo ...
- R语言、02 案例2-1 Pelican商店、《商务与经济统计》案例题
编程教材 <R语言实战·第2版>Robert I. Kabacoff 课程教材<商务与经济统计·原书第13版> (安德森) P48.案例2-1 Pelican 商店 PS C: ...