官方的开发文档

微信小程序写的不多,随便写写

创建项目,分析工具

微信小程序有专门的编辑工具,去官网下载

然后申请一个小程序项目,获得一个appId,然后进入编辑工具就可以直接开发了

编辑工具可以设置es6编译和npm

文件分析

小程序的写法非常的像vue-cli,但是vue是一个vue文件带有html+js+css

小程序是一个页面分为四个文件,wxml+js+wxss+json(配置页面)

还有一个app.json总配置页面,一个app.js入口文件,一个app.wxss的全局css文件

新建页面

  • 在目录树上右键,选择新建 Page,将自动生成页面所需要的 wxml、wxss、js、json
  • 在 app.json 的 pages 字段,添加需要新建的页面的路径,将会自动生成该页面所需要的文件

app.json

  • 页面要被识别必须配置在app.json的page数组里,数组的第一个就是打开小程序的第一个页面,这个page数组就是vue的router.js
  • 小程序的底部菜单tabbar栏也是在这个文件里配置的,可以配置文字,图标,被选中的图标,点击的路由
  • 还有个window的对象是配置小程序的顶部颜色什么的,这个文件很重要,配置查看官方文档

app.js

入口文件就是main.js,用来配置插件什么的,还有就是在入口文件的生命周期里执行用户登陆,获取用户信息什么的

wxss

wxss的图片引入需使用外链地址;

没有 Body;

样式可直接使用 import 导入;

字体宽高用vw和vh最好

生命周期

onLaunch: function(options) {
// 监听小程序初始化。小程序初始化完成时(全局只触发一次)
},
onReady: function(options) {
// 页面初次渲染完成
// 一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互。
},
onShow: function(options) {
// 监听小程序显示。小程序启动,或从后台进入前台显示时,执行很多次
},
onHide: function() {
// 监听小程序隐藏。小程序从前台进入后台时。
},
onUnload: function() {
// 当redirectTo或navigateBack的时候调用。
// Do something when page close.
},
onPullDownRefresh: function() {
// 监听用户下拉动作
// 需要在页面json里配置 "enablePullDownRefresh": true
},
onReachBottom: function() {
// 页面上拉触底事件的处理函数
// 需要在页面json里配置 "enablePullDownRefresh": true
},
onShareAppMessage: function () {
// 用户点击右上角转发
},
onPageScroll: function() {
// 页面滚动触发事件的处理函数
},
onResize: function() {
// 页面尺寸改变时触发
},
onTabItemTap(item) {
// 当前是 tab 页时,点击 tab 时触发
console.log(item.index)
console.log(item.pagePath)
console.log(item.text)
},

渲染

// 数据绑定
<checkbox checked="{{xx}}"
id="item-{{id}}"
hidden="{{flag ? true : false}}">{{ name }}</checkbox> // 条件渲染
<view wx:if="{{length > 5}}"> 1 </view>
<view wx:elif="{{length > 2}}"> 2 </view>
<view wx:else> 3 </view> // 循环渲染
<view wx:for="{{array}}" wx:for-index="idx" wx:for-item="item" wx:key="idx">
{{idx}}: {{item.name}}
</view>

组件

小程序的组件就是指html的标签,不过是内部的标签,微信对标签进行了封装,自带了像轮播图,图标icon组件,还有地图,画布,摄像头等等东西,让开发便捷了很多

小程序里没有div,view组件就是div

API

微信内置的方法,有登陆的,转格式的,上传文件的,发起请求的,路由跳转的,定时器,websocket,地图的,获取位置的,选择相册图片,视频,音频,画布,录音,相机,富文本,支付,扫码甚至微信运动,蓝牙,NFC充值,卡包,手机电量,陀螺仪,移动方向等等

请求响应

小程序也是用的跨域接口,需要在微信小程序后台配置接口白名单,配置后就可以访问了,必须是域名的,不能是localhost或者ip地址

数据传递

  • 在app.js里有个全局数据对象
globalData:{
userInfo:null
}
// 获取
var app=getApp();//取得全局App({..})实例
var userInfo = app.globalData.userInfo;//取得全局变量需要的值
// 获取data的值
var xx = this.data.xx
  • 通过本地缓存,setStorage和getStorage
  • 通过路由传参
wx.navigateTo({
url: '/pages/item/item?url=' + e.target.dataset.url
}) onLoad: function (options) {
var that = this;
console.log(options.url)
}
  • 从标签上获取data值
<view bindtap="play" data-xx="xx"></view>
play:function(event){
var xx= event.currentTarget.dataset.xx;
}

路由跳转

  • navigateTo 保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。使用 wx.navigateBack 可以返回到原页面。小程序中页面栈最多十层。
  • redirectTo 关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面。
  • reLaunch 关闭所有页面,打开到应用内的某个页面
  • switchTab 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面

接入资源

腾讯自己家的东西都带有小程序接入的功能

比如腾讯地图

比如腾讯视频

具体查看文档

内置组件

其实也不是内置,也需要自己下载

就是weui-weapp,在微信小程序官方文档的拓展能力里有如何使用的教程

外来组件

vant-weapp

通过npm下载安装就行,用一些弹窗什么的很爽

小程序框架

  • 美团点评:mpvue
  • 京东:Taro
  • 腾讯:WePY

总结:京东的是 React 方式编码,其他多数是vue方式。不考虑框架

发布

代码写完,可以直接在开发工具里提交,然后等待微信工作人员审核,审核完毕可以就可以去到微信小程序后台点击发布,就可以在手机微信里找到这个小程序了

最后总结

小程序只要js基础好,写过vue,上手非常的快,特别是在微信平台上开发,兼容等问题就很少了,而且API特别的多,去看官网就知道,真正的copy型程序员诞生之路

app.js

App({
onLaunch: function () {
//调用API从本地缓存中获取数据
var logs = wx.getStorageSync('logs') || []
logs.unshift(Date.now())
wx.setStorageSync('logs', logs)
},
getUserInfo:function(cb){
var that = this
if(this.globalData.userInfo){
typeof cb == "function" && cb(this.globalData.userInfo)
}else{
//调用登录接口
wx.login({
success: function () {
wx.getUserInfo({
success: function (res) {
that.globalData.userInfo = res.userInfo
typeof cb == "function" && cb(that.globalData.userInfo)
}
})
}
})
}
},
globalData:{
userInfo:null
}
})

有时间补充个自定义组件

微信小程序是什么的更多相关文章

  1. 微信小程序开发心得

    微信小程序也已出来有一段时间了,最近写了几款微信小程序项目,今天来说说感受. 首先开发一款微信小程序,最主要的就是针对于公司来运营的,因为,在申请appid(微信小程序ID号)时候,需要填写相关的公司 ...

  2. 微信小程序体验(2):驴妈妈景区门票即买即游

    驴妈妈因为出色的运营能力,被腾讯选为首批小程序内测单位.驴妈妈的技术开发团队在很短的时间内完成了开发任务,并积极参与到张小龙团队的内测问题反馈.驴妈妈认为,移动互联网时代,微信是巨大的流量入口,也是旅 ...

  3. 微信小程序(微信应用号)组件讲解

    这篇文章主要讲解微信小程序的组件. 首先,讲解新建项目.现在有句话:招聘三天以上微信小程序开发,这个估计只能去挖微信的工程师了.技术新,既然讲解,那我们就从开始建项目讲解. 打开微信web开发者工具, ...

  4. 神技!微信小程序(应用号)抢先入门教程(附最新案例DEMO-豆瓣电影)持续更新

    微信小程序 Demo(豆瓣电影) 由于时间的关系,没有办法写一个完整的说明,后续配合一些视频资料,请持续关注 官方文档:https://mp.weixin.qq.com/debug/wxadoc/de ...

  5. 通过微信小程序看前端

    前言 2016年9月22日凌晨,微信官方通过“微信公开课”公众号发布了关于微信小程序(微信应用号)的内测通知.整个朋友圈瞬间便像炸开了锅似的,各种揣测.介绍性文章在一夜里诞生.而真正收到内测邀请的公众 ...

  6. 快速了解微信小程序的使用,一个根据小程序的框架开发的todos app

    微信官方已经开放微信小程序的官方文档和开发者工具.前两天都是在看相关的新闻来了解小程序该如何开发,这两天官方的文档出来之后,赶紧翻看了几眼,重点了解了一下文档中框架与组件这两个部分,然后根据简易教程, ...

  7. 来自于微信小程序的一封简讯

    9月21晚间,微信向部分公众号发出公众平台-微信应用号(小程序)的内测邀请,向来较为低调的微信在这一晚没人再忽视它了. 来自个人博客:Damonare的个人博客 一夜之间火了的微信应用号你真的知道吗? ...

  8. 微信小程序前端源码逻辑和工作流

    看完微信小程序的前端代码真的让我热血沸腾啊,代码逻辑和设计一目了然,没有多余的东西,真的是大道至简. 废话不多说,直接分析前端代码.个人观点,难免有疏漏,仅供参考. 文件基本结构: 先看入口app.j ...

  9. 微信小程序初探

    做为码农相信大家最近肯定都会听到微信小程序,虽然现阶段还没有正式开放注册,但大家可以还是可以开发测试. 到微信的WIKI(http://mp.weixin.qq.com/wiki?t=resource ...

  10. 【微信小程序开发】之如何获取免费ssl证书【图文步骤】

    微信小程序要求所有网络请求都走ssl加密,因此我们开发服务端接口需要配置为https 这篇文章介绍一下如何 在 startssl 申请一个免费的ca证书. 1. 打开网站  https://www.s ...

随机推荐

  1. Mysql将2张字段不同的表拼接起来

    select id,mobile,realname as name,weixin as message_note,address_des as address,create_time,cateid f ...

  2. 吴裕雄--天生自然ORACLE数据库学习笔记:PL/SQL编程

    set serveroutput on declare a ; b ; c number; begin c:=(a+b)/(a-b); dbms_output.put_line(c); excepti ...

  3. 【原】Linux中常见服务介绍

    1.SSH介绍 简单说,SSH(Secure Shell Protocol)是一种网络协议,用于计算机之间的加密登录.在默认状态下SSH服务提供俩个服务功能,一个是提供类似telnet远程联机服务器的 ...

  4. Python环境搭建-3 Python下载

    python环境搭建 Python是一个跨平台.可移植的编程语言,因此可在windows.Linux和Mac OS X系统中安装使用. 安装完成后,你会得到Python解释器环境,可以通过终端输入py ...

  5. 前端代码编译器Hbuilder下载地址和谷歌浏览器下载地址

    编译器:HbuilderX 浏览器:谷歌浏览器

  6. http-equiv属性的属性值X-UA-Compatible

    参考:https://blog.csdn.net/changjiangbuxi/article/details/26054755

  7. vue使用H5实现滚动到页面底部时加载数据

    使用原生vue实现瀑布流,发现无法实现小程序那种滚动到地步触发加载效果,只能自己研究了 实现效果: 实现代码: 首先添加监听滚动事件 mounted() { window.addEventListen ...

  8. Linux系统资深运维工程师的进阶秘籍

    2010年毕业,从事IT行业已经接近7个年头,一路走来有很多不足,不论是技术上的还是工作当中的待人接事等,但正是这些不足让我有了现在的进步,技术上从最初的做水晶头,综合布线到服务器上架,网络设备调试, ...

  9. bzoj 4487: [Jsoi2015]染色问题

    先贴一个题解吧,最近懒得要死2333,可能是太弱的原因吧,总是扒题解,(甚至连题解都看不懂了),blog也没更新,GG http://blog.csdn.net/werkeytom_ftd/artic ...

  10. 深入理解python(二)python基础知识之数据结构

    数据结构 Python中的内置数据结构(Built-in Data Structure):列表list.元组tuple.字典dict.集合set,这里只着重说前三个 >>> d=di ...