一、小程序简介

1、小程序与普通网页开发的区别

  • 运行环境不同

    • 网页运行在浏览器环境中
    • 小程序运行在微信环境中
  • API不同

    • 小程序无法调用浏览器中的DOM和BOM的API
    • 但是小程序可以调用微信环境提供的各种API,地理定位、扫码、支付等等
  • 开发模式不同

    • 网页的开发模式:浏览器 + 代码编辑器
    • 小程序的标准开发模式
      • 申请小程序开发账号
      • 安装小程序开发者工具
      • 创建和配置小程序项目

2、注册小程序账号

  1. 打开 https:// mp.weixin.qq.com/ 网址,点击立即注册按钮,选择小程序,按照步骤进行注册
  2. 获取小程序的 AppID(创建小程序项目的时候需要用到)

3、安装开发者工具

3.1、开发者工具的功能:

  • 快速创建小程序项目

  • 代码的查看和编辑

  • 对小程序功能进行调试

  • 小程序的预览和发布

3.2、下载 稳定版 的开发者工具

  1. 打开 首页 | 微信开放社区 (qq.com) 网址,点击文档 之后,按照下面的步骤进去下载页面
  2. 选择稳定版的下载链接进行下载

    3. 找到下载的安装包,打开直接安装就好啦!

   

3.3、设置外观和代理

  • 点击设置,按自己的爱好设置外观

  • 为了方便学习,代理哪里勾选第一个:不使用任何代理

二、小程序起步

1、创建小程序项目

  1. 点击 “ + ” 号
  2. 填写相关信息

  

  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、小程序的启动过程

  1. 把小程序的代码包下载到本地

  2. 解析 app.json 全局配置文件

  3. 执行 app.js 小程序人口文件,调用 App() 创建小程序实例

  4. 渲染小程序首页

  5. 小程序启动完成

9.2、页面渲染的过程

  1. 加载解析页面的 .json 配置文件

  2. 加载页面的 .wxml 模板和 .wxss 样式

  3. 执行页面的 .js 文件,调用 Page() 创建页面实例

  4. 页面渲染完成

10、组件

10.1、组件的分类

  1. 视图容器

    • view
      • 普通视图区域
      • 类似于 HTML 中的 div,是一个块级元素
      • 常用于实现页面的布局效果
    • scroll-view
      • 可滚动的视图区域
      • 常用于实现滚动列表效果
    • swiper 和 swiper-item
      • 轮播容器组件 和 轮播图 item 组件  
  2. 基础内容

    • text
      • 文本组件
      • 类似于 HTML 中的 span 标签,是一个行内元素
    • rich-text
      • 富文本组件
      • 支持把 HTML 字符串渲染为 WXML 结构  
  3. 其他常用组件

    • navigator

      • 页面导航组件
      • 类似于 HTML 中的超链接
    • image
      • 图片组件
      • image 组件默认宽度为 300px、高度为 240px
    • button
      • 按钮组件
      • 功能比 HTML 中的 button 按钮丰富
      • 通过 open-type 属性可以调用微信提供的各种功能(客服、转发、获取用户授权、获取用户信息等)   
  4. 表单组件

  5. 导航组件

  6. 媒体组件

  7. map 地图组件

  8. canvas 画布组件

  9. 开放能力

  10. 无障碍访问

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、不同成员对应的权限

微信小程序的学习(一)的更多相关文章

  1. 微信小程序js学习心得体会

    微信小程序js学习心得体会 页面控制的bindtap和catchtap 用法,区别 <button id='123' data-userDate='100' bindtap='tabMessag ...

  2. 微信小程序入门学习

    前(che)言(dan): 近几天,微信小程序的内测引起了众多开发人员的热议,很多人都认为这将会成为一大热门,那么好吧,虽然我是一个小白,但这是个新玩意,花点时间稍稍钻研一下也是无妨的,谁让我没有女朋 ...

  3. 微信小程序开发学习资料

    作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  4. 微信小程序入门学习-- 简易Demo:计算器

    简单学习下微信小程序 官网 简易教程 · 小程序 https://mp.weixin.qq.com/debug/wxadoc/dev/ 需要通过开发者工具,来完成小程序创建和代码编辑. 下载安装,运行 ...

  5. 微信小程序组件学习 -- 注册页面

    微信小程序组件使用手册地址: 1. 百度搜索"微信公众平台",扫码登录之后,点击帮助文档里面的普通小程序. 2. 接着选择"开发"-->"组件& ...

  6. 微信小程序开发学习(一):开发前准备

    开发前准备 Step1:注册 微信小程序开放平台: https://mp.weixin.qq.com/cgi-bin/wx 开发者注册: https://mp.weixin.qq.com/wxopen ...

  7. 第1-5章 慕课网微信小程序开发学习笔记

    第1章 前言:不同的时代,不同的Web --微信小程序商城构建全栈应用 http://note.youdao.com/noteshare?id=a0e9b058853dbccf886c1a890594 ...

  8. 微信小程序开发学习记录

    两天撸了一遍小程序的文档,跟网页相似,个人感觉是简化版.但是因为开放了很多微信自带的接口又使得部分功能开发起来相对方便 思维导图如下: 目前我的理解大概是这么个逻辑,以后深入学习后可能会有更改 跟着大 ...

  9. 微信小程序入门学习之事件 事件对象 冒泡非冒泡事件(1)

    这关于事件的学习,可以自己复制到微信开发者工具上自己运行试试. 首先这里有两个文件.js 和.wxml 文件 首先给出.js文件下代码 // pages/news/news.js Page({ /** ...

  10. 微信小程序开发学习(二)

    一些官方API 总结了一些官方API,便于之后有用时针对性查找(发现官方给了好多好用的API)官方API文档 基础 wx.canIUse:判断小程序的API,回调,参数,组件等是否在当前版本可用,返回 ...

随机推荐

  1. 简单创建一个SpringCloud2021.0.3项目(四)

    目录 1. 项目说明 1. 版本 2. 用到组件 3. 功能 2. 上三篇教程 3. 日志处理 1. 创建日志公共模块 2. Eureka引入日志模块 4. 到此的功能代码 5. 注册中心换成naco ...

  2. 应用性能监控:SkyWalking

    目录 SkyWalking 简介 SkyWalking 搭建 平台后端(Backend) 平台前端(UI) Java Agent(Java 应用监控) Java Agent 下载 Java 演练项目 ...

  3. 第五十一篇:webpack中的loader(二) --less-loader

    好家伙 先扩充一下知识点: 什么是.less文件? 作为一名前端开发的同学,很多时候我们都无法避免地要去写大量的 CSS 代码, 而且耗费的时间还不少,所以学习一种能够提升开发效率的 CSS 预处理器 ...

  4. Python入门系列(十一)一篇搞定python操作MySQL数据库

    开始 安装MySQL驱动 $ python -m pip install mysql-connector-python 测试MySQL连接器 import mysql.connector 测试MySQ ...

  5. 【ACG】博主在专栏更新内容后,及时通知关注他的用户去阅读

    ​ 业务场景 当用户打开应用时,系统发送Push消息给用户,向用户推荐博主信息.用户关注博主后,将保存用户的订阅信息,当关注的博主更新内容时,向订阅的用户发送短信,提醒用户及时查看最新内容.从而持续增 ...

  6. ThreadLocal源码学习笔记

    系列文章目录和关于我 一丶ThreadLocal结构 每一个Thread对象都有一个名为threadLocals类型为ThreadLocal.ThreadLocalMap的属性,ThreadLocal ...

  7. 痞子衡嵌入式:理解i.MXRT中FlexSPI外设lookupTable里配置访问行列混合寻址Memory的参数值

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT中FlexSPI外设lookupTable里配置访问行列混合寻址Memory的参数值. 关于 FlexSPI 外设的 loo ...

  8. 微服务系列之授权认证(二) identity server 4

    1.简介 IdentityServer4 是为ASP.NET Core系列量身打造的一款基于 OpenID Connect 和 OAuth 2.0 认证授权框架. 官方文档:https://ident ...

  9. logstash知识点

    Logstash是位于Data和Elasticsearch之间的一个中间件.Logstash是一个功能强大的工具,可与各种部署集成. 它提供了大量插件. 它从数据源实时地把数据进行采集,可帮助您解析, ...

  10. Alertmanager 概念与配置深入介绍

    文章转载自:https://www.cnblogs.com/gered/p/13496950.html 警报一直是整个监控系统中的重要组成部分,Prometheus监控系统中,采集与警报是分离的. 报 ...