概述
微信开发即将企业信息、服务、活动等内容通过微信网页的方式进行表现,用户通过简单的设置,就能生成微信网站(比如微信订阅号、服务号 企业账号、微信小程序等)。 微信对外提供了例如聊天、支付、分享、收藏等功能,同时还提供了丰富的封装好的接口,开发者利用这些接口和功能,写入程序中,进行的开发。
目的
(1)企业开发的需要,使自己更加符合企业发展的需求 (2)个人(开发者)的发展以及技能的提升 (3)发展前景大、生态系统丰富
平台
(1)微信开放平台(服务端使用) (2)微信公众平台(前端使用)
概述
微信开放平台是微信对外提供微信开发接口的一个平台,这些开发出来的微信接口,供第三方的网站或App使用,使用户可将第三方程序的内容发布给好友或分享至朋友圈,第三方内容借助微信平台获得更广泛的传播。
平台地址:微信开放平台
微信开放平台提供的能力
微信分享、 微信支付、 微信登录、微信收藏、微信分享等等
产品应用
(1)网站应用开发 (2)移动应用开发 (3)第三方平台开发 (4)公众帐号开发
只有通过 开发者资质认证后,才能使用开发平台提供的能力
个人基本不具备使用开放平台接口的权限,一般是需具有企业资质,比如微信支付,微信登录等
微信公众平台,简称公众号。曾命名为官号平台、媒体平台、微信公众号,最终定位为公众平台。 微信公众平台是运营者通过公众号为微信用户提供资讯和服务的平台。 利用公众账号平台进行自媒体活动,简单来说就是进行一对多的媒体性行为活动,如商家通过申请公众微信服务号通过二次开发展示商家微官网、微会员、微推送、微支付、微活动、微报名、微分享、微名片等,已经形成了一种主流的线上线下微信互动营销方式。 平台网址:https://mp.weixin.qq.com
微信公众账号分为订阅号、服务号、小程序(小游戏)、企业微信(原企业号)
1.开放平台 (1)微信对外开放接口的平台 (2) 开放的接口,供其他网站及App使用 (3)后端程序员是开放平台开发的主力军 2.公众平台 (1) 基于微信公众号,为微信用户提供服务的平台 (2) 所用公众号,都属于微信内开发 (3)前端程序员是公众平台开发的主力军
微信小程序,简称小程序,英文名Wechat Mini Program,是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或搜一下即可打开应用。 小程序是一种新的开放能力,开发者可以快速地开发一个小程序。小程序可以在微信内被便捷地获取和传播,同时具有出色的使用体验。 全面开放申请后,主体类型为企业、政府、媒体、其他组织或个人的开发者,均可申请注册小程序。小程序、订阅号、服务号、企业号是并行的体系。 2010-2011年智能手机流行开始; 2011年为了解决智能移动设备及时通讯研发了微信,同步产品有米聊,先后微信又发布了微信公众号产品,如订阅号、服务号等,但是这些账号产品在功能无法媲美原生App,所以这就有了微信小程序这种新的账号类型的形态; 2017年1月初微信小程序产品正式上线发布。(微信之父:张小龙) 所以小程序可以理解为是一个简化版app应用 米聊 雷军 更新慢
微信小程序开发,非常适合一些轻量级、即开即用、用完即走的应用。 例如点外卖、打车、代驾、共享单车、乘车码、行程码等。对于一些大型的重依赖应用,不太适合,比如大型手机游戏类、音乐播放器、银行金融类app等 小程序常见案例:学习城一卡通、北京健康宝、国务院客户端等
1)亮点 对于用户而言: 不需要下载,节省了手机内存,使用方便,即开即用、用完即走 打开速度比普通的H5要快,接近原生APP 对于开发者而言: 功能上媲美原生app,比h5强大; 成本上比原生app低(时间 服务器资金 ),接近h5应用开发成本; 入门门槛较低,掌握基本的html、css、js语法即可快速上手; 生态圈越来越丰富,依托微信、流量巨大 2)不足 小程序目前只有2M大小,使用分包加载可达到20M ios目前不能直接分享到朋友圈,Android目前支持Beta测试版 不能即时发布,需要微信团队进行审核,审核周期1-7天 对个人开发者开发的服务项目限制非常大。
1.在微信公众平台官网首页(mp.weixin.qq.com)点击右上角的“立即注册”按钮 2.选择注册的帐号类型(小程序) 3.填写邮箱和密码(请填写未注册过公众平台、开放平台、企业号、未绑定个人号的邮箱) 4.激活邮箱(登录邮箱,查收激活邮件,点击激活链接) 5.填写主体信息(选择主体类型(个人)、完善主体信息和管理员信息)
4.激活邮箱
注意如果邮件发送成功在收件箱看不到就去垃圾箱找找
5.填写主体类型
填写个人即可
1.基本信息 发布上线小程序之前需要填写基本信息,如小程序的头像、名称和简介等,注意项目服务类型,不要填写小游戏 2.项目成员 管理员:小程序的拥有者,具有后台一切最高权限 项目成员 :按照权限可以分为运营者 开发者 数据分析者 有管理员添加管理 体验成员:仅具有使用体验版小程序权限,管理员和项目成员都能添加删除管理 3.版本管理 开发版本:本地代码开发完毕 有微信开发者工具提交产生,可以被项目成员和体验成员访问 审核版本:有开发版本提交产生,需要微信团队审核,审核周期1-7天 线上版本:有审核版本提交产生,可以被所有的微信用户访问 4.开发管理 AppID(小程序ID):项目创建、云开发使用、项目发布等 AppSecret(小程序密钥):加解密用户的私密数据,如获取用户手机号
首先小程序开发不同于普通的网页开发,项目不能运行在浏览器中,所以无法查看编程效果以及调试,微信开发者工具提供了代码的编程能力,调试能力以及展示运行效果能力等强大的功能
地址:稳定版 Stable Build | 微信开放文档
建议大家下载稳定的版本即可,下载完毕直接安装即可,预发布版和开发版工具中的功能比较全但是不稳定容易卡死、出现起点启动失败等问题。
扫码登录工具点击加号创建项目 如下所示:
设置自动缩放代码
手写项目目录
pages: 页面总目录 每个页面都是有 .js .json .wxml .wxss四个文件构成 .js:页面逻辑 =====>pc端 js .json:页面配置文件 .wxml:页面结构 =====>pc端 html .wxss:页面样式 =====>pc端 css utils: 工具目录 常用函数等 app.js: 微信小程序入口文件 完成小程序的实例注册 app.json: 微信小程序的全局配置文件 app.wxss: 微信小程序的全局样式文件 project.config.json: 记录开发者的偏好设置,比如工具界面ui颜色、编译配置、appid、域名校验等 sitemap.json: 站点地图配置文件,用来配置是否允许微信爬虫爬取我们小程序的页面,可以优化提高我们小程序的曝光率 eslint.js: eslint校验配置文件
地址:小程序配置 | 微信开放文档
小程序提供了json文件用来对微信小程序进行配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 等,主要分为全局配置及页面配置
小程序根目录下的 app.json 文件用来对微信小程序进行全局配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 等。文件内容为一个 JSON 对象
1.entryPagePath: 功能:
小程序默认启动首页
语法:
"entryPagePath": "pages/logs/logs",
注意事项:
1.页面路由一定是存在于pages配置项中的 存在合法的地址路由 2.如果不设置此配置 默认会以pages中的第一项作为项目的首页
2.pages:
功能:
1.指定项目的路由信息 2.可以指定项目的默认启动首页(没有配置entryPagePath) 3.快速创建页面,直接写路由信息保存即可
使用语法:
"pages": [ "pages/cart/cart", "pages/index/index", "pages/logs/logs", "pages/user/user" ],
注意事项:
1.[ app.json 文件内容错误] app.json: ["pages"][0] 不应该以 '.' 开头 2.[ app.json 文件内容错误] app.json: ["pages"][0] 不应该以 '/' 开头 3.配置项最后不要多加逗号
3.window:
窗口构成如下:
功能:
配置心目中的导航条 状态栏 窗口背景色 屏幕旋转等
使用语法:
"window": { "navigationBarBackgroundColor": "#f00", "navigationBarTitleText": "微信小程序", "navigationBarTextStyle": "white", "navigationStyle": "default", "enablePullDownRefresh": true, "backgroundColor": "#DDD", "backgroundTextStyle":"dark", "pageOrientation":"portrait" },
使用注意:
1.注意自定义导航栏胶囊会保留 2.需要开发者手动关闭刷新动画(数据更新完毕)
4.tabbar
功能:
实现项目中置顶或者是在底部的选项卡效果
使用语法:
"tabBar": { "position": "top", "backgroundColor": "#DDD", "borderStyle": "black", "color": "#000", "selectedColor":"f00", "list": [{ "pagePath": "pages/index/index", "text": "首页", "iconPath": "images/icon/index.png", "selectedIconPath": "images/icon/indexFull.png" }, { "pagePath": "pages/user/user", "text": "我的", "iconPath": "./images/icon/my.png", "selectedIconPath": "/images/icon/myFull.png" } ] },
使用注意:
1.首先选项卡数量最少2个 最多5个(符合人体工程学) 2.当 position 为 top 时,不显示 icon。 3.只有页面底部绑定选项卡的才会显示选项卡效果
5.debug
功能:
方便测试调试,可以打印项目从启动到页面加载完毕的所有信息,比如:Page 的注册,页面路由,数据更新,事件触发
使用语法:
"debug": true,
地址:小程序配置 | 微信开放文档
每一个小程序页面也可以使用同名 .json 文件来对本页面的窗口表现进行配置,页面中配置项会覆盖 app.json 的 window 中相同的配置项。
使用语法:
{ "usingComponents": {}, "navigationBarBackgroundColor": "#000", "enablePullDownRefresh": false, "disableScroll":true }
使用注意:
1.页面配置中只能设置 app.json 中 window 对应的配置项,以决定本页面的窗口表现,所以无需写 window 这个属性 2.disableScroll此配置项只能在页面json文件中设置 全局无效
地址:场景值 | 微信开放文档
场景值用来描述用户进入小程序的方式,比如小程序最近使用列表、扫描二维码、小程序主入口等
使用语法:
1. App 的 onLaunch 和 onShow 2. 通过wx.getLaunchOptionsSync()函数获取 // 使用api函数获取场景值(同步函数 直接接值) let info = wx.getLaunchOptionsSync(); console.log(info) App({ onLaunch(e) { console.log(e.scene); }, onShow(e){ console.log(e.scene) } })
获取更多场景值:
通过点击工具栏----->编译模式--->新增编译模式----->添加场景值
场景值使用场景非常广泛: 比如通过微信下拉进入小程序,提示收藏加券功能、比如快餐店通过扫码和搜索进入不同的页面等等 比如获取到场景值为1008,表示用户是通过微信群内分享的卡片进入的小程序,可以显示一些群内排行和群内好友信息等
整个小程序框架系统分为两部分:逻辑层(App Service)和 视图层(View)。vc结构
小程序开发框架的逻辑层使用 JavaScript 引擎为小程序提供开发者 JavaScript 代码的运行环境以及微信小程序的特有功能。 逻辑层将数据进行处理后发送给视图层,同时接受视图层的事件反馈。 开发者写的所有代码最终将会打包成一份 JavaScript 文件,并在小程序启动的时候运行,直到小程序销毁。这一行为类似 ServiceWorker,所以逻辑层也称之为 App Service。 Tips: 小程序框架的逻辑层并非运行在浏览器中,因此 JavaScript 在 web 中一些能力都无法使用,如 window,document 等。
每个小程序都需要在 app.js 中调用 App 方法注册小程序实例, app方法内容:绑定生命周期回调函数、错误监听和页面不存在监听函数、自定义全局函数和自定义全局变量等。 App() 必须在 app.js 中调用,必须调用且只能调用一次。不然会出现无法预期的后果
app方法语法:
// app.js // 使用api函数获取场景值(同步函数 直接接值) // let info = wx.getLaunchOptionsSync(); // console.log(info) App({ // 监听小程序初始化。 //冷启动:如果用户首次打开,或小程序销毁后被用户再次打开,此时小程序需要重新加载启动,即冷启动。 //热启动:如果用户已经打开过某小程序,然后在一定时间内再次打开该小程序,此时小程序并未被销毁,只是从后台 //状态进入前台状态,这个过程就是热启动。 onLaunch(e) { // this ===>app实例 // console.log(this); // 调用不存在的api函数 // this.user(); // 调用存在的api函数 this.user(); this.users(); this.userss(); // 应用场景:1.检测用户是否登录 2.记录用户的访问日志 // 3.处理基础库兼容性 4.选择云环境id 5.获取场景值 console.log('执行了onLaunch') //获取场景值: //console.log(e.scene); // 展示本地存储能力 const logs = wx.getStorageSync('logs') || [] logs.unshift(Date.now()) wx.setStorageSync('logs', logs) // 登录 wx.login({ success: res => { // 发送 res.code 到后台换取 openId, sessionKey, unionId } }) }, // 监听小程序启动或切前台。 onShow(e){ // 应用场景:1.获取场景值 2.检测用户切后台时间(用户留存) console.log('执行了onshow') // 获取场景值: // console.log(e.scene) }, // 监听小程序切后台。 onHide(){ // 应用场景:1.检测用户切后台时间(用户留存) console.log('执行了onHide') }, // 监听函数 小程序发生脚本错误或 API 调用报错时触发。 onError(e){ console.log('检测到了错误',e) // 应用场景:统计错误详情 可以将错误信息发送到后端 做数据可视化统计 // wx.request({ // url: 'http://ceshi.com?error='+e, // }) }, // 监听函数 小程序要打开的页面不存在时触发。 onPageNotFound(){ console.log('访问的页面不存在'); // 应用场景: 帮助用户重定向到存在页面 使用路由跳转方法 wx.switchTab({ url: 'pages/index/index', }) }, // ==========================全局函数============================ // 1.声明式定义函数 user:function(){ console.log('声明式定义函数') console.log(this); }, // 2.ES6简写(提倡 ) users(){ console.log('简写定义函数') console.log(this); }, //3.箭头函数 userss:()=>{ console.log('我是箭头函数') console.log(this);//undefined }, // ==========================全局变量============================ globalData: { userInfo: null, name:'鲁班', array:[1,2,3,4], userInfo:[{id:11,age:20},{id:12,age:30}] } })
获取app实例:
getApp(); 如在index页面使用 index.js页面代码如下: // 获取应用实例 const app = getApp(); console.log(app)
在每一个独立页面的js文件中,使用Page( Object object )注册页面,接受一个 Object 类型参数 page方法内容:页面的初始数据data、生命周期回调、事件处理函数、自定义事件等。
page方法语法:
// index.js // 获取应用实例 const app = getApp(); // console.log(app) // 使用page方法完成页面注册 Page({ /** * 页面的初始数据 同vue data */ data: { name:'李白' }, // ==========================自定义事件============================ // 1.声明式定义函数 user:function(){ console.log('声明式定义函数') console.log(this); }, // 2.ES6简写(提倡 ) users(){ console.log('简写定义函数') console.log(this); }, //3.箭头函数 userss:()=>{ console.log('我是箭头函数') console.log(this);//undefined }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { // 应用场景:1.可以获取页面跳转传递的参数 // console.log('参数是:',options) // A(name='李四')--->B(onload) // 2.获取网络接口数据 console.log('触发了页面的onload') // 使用自定义函数 // this.user(); // this.users(); // this.userss(); }, /** * 生命周期函数--监听页面显示 */ onShow: function () { // 应用场景:1.获取网络接口数据 console.log('触发了页面的onshow') }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () { // 应用场景:1.获取页面上元素的位置 console.log('触发了页面的onReady') }, /** * 生命周期函数--页面隐藏/切入后台时触发。 */ onHide: function () { // 触发条件: wx.navigateTo 或底部 tab 切换到其他页面 console.log('触发了页面的onhide') }, /** * 生命周期函数--监听页面卸载 */ onUnload: function () { // 触发条件:wx.redirectTo或wx.navigateBack到其他页面时 console.log('触发了页面的onUnload') } })
微信小程序的生命周期同vue一样,也是不需要立马搞明白,后续根据业务需要渐进式使用即可; 微信小程序的生命周期可以分为两种:一种是app.js文件中的应用级别的生命周期,另一种就是页面.js文件中的生命周期; 当我们进入小程序应用的时候首先执行app.js文件中的生命周期函数再次执行要访问的页面中的生命周期函数,切后台的时候先执行页面的生命周期函数再次执行app.js文件中的应用级别的生命周期函数
微信小程序中完全支持模块化规范,ES6和commonjs规范; 微信小程序完全支持commonjs和ES6模块化规范 1.commonjs 导出 :module.exports exports 是module.exports的引用 引入:requrie('文件路径') 2.ES6 导出:export {} export default 引入:import {} '文件路径' import from '文件路径'
如在utils/tip.js文件 // =======================commonjs规范=============================== // 定义一个弹窗方法 const tip=(title,icon)=>{ wx.showToast({ title,icon }) } // 定义数据加载提示方法 const load=(title)=>{ wx.showLoading({ title }) } // 导出 // 1.module.exports={ // tip, // load // } // 2.exports.info={tip,load} // exports是module.exports的引用 // =======================ES6规范=============================== // 1.export {tip,load}; // 2.export default 在index页面使用如下: // 引入提示模块文件(common规范引入) // let {tip,load} = require('../../utils/tip') // tip('温馨提示!','error') // load('数据加载中'); // 引入提示模块文件(ES6规范引入) import {tip,load} from '../../utils/tip'; tip('温馨提示');