[TOC]
# 小程序
## 小程序簡介
### 文檔與結構
小程序結構圖

**app.json文件小程序設置全局配置 ,包括頁面路徑、窗口、選項卡,以及網絡超時等
app.js文件中App()來注冊一個小程序 提供了生命周期方法
app.wxss小程序應用的樣式文件**
小程序文件結構圖
### 知識儲備
* 首先得有一定的網站開發基礎(html css js)
* 因為不能像做網站那樣用js中的window,document方法,所以要多看官網給的api文檔
* 全新的一個模式,好多東西微信自己都還沒定下來,所以就是要多看多練。
* 由于大小限制,所以不適合做大型開發。
## 小程序常用的API和邏輯綁定方法
**wx.request https網絡請求**
~~~
wx.request({
url: 'test.php', //僅為示例,并非真實的接口地址
method:"GET",
data: {
x: '' ,
y: ''
},
header: {
'content-type': 'application/json'
},
success: function(res) {
console.log(res.data)
}
})
~~~
**本地緩存**<br>
**通過key的形式添加緩存setStorage (異步接口)**
~~~
wx.setStorage({
key:"key"
data:"value"
})
~~~
**通過key的形式獲取緩存getStorage (異步接口)**
~~~
wx.getStorage({
key: 'key',
success: function(res) {
console.log(res.data)
}
})
~~~
**從本地緩存中異步移除指定 key**
~~~
wx.removeStorage({
key: 'key',
success: function(res) {
console.log(res.data)
}
})
~~~
**清理本地數據緩存**
~~~
wx.clearStorage()
顯示、隱藏消息提示框
wx.showToast({
title: '加載中',
icon: 'loading',
duration: 10000
})
setTimeout(function(){
wx.hideToast()
},2000)
~~~
**動態設置當前頁面的標題**
~~~
wx.setNavigationBarTitle({
title: '當前頁面'
})
~~~
**導航**
**保留當前頁面,跳轉到應用內的某個頁面**
~~~
wx.navigateTo({
url: 'test?id=1'
})
~~~
**關閉當前頁面,跳轉到應用內的某個頁面**
~~~
wx.redirectTo({
url: 'test?id=1'
})
~~~
**獲取用戶信息,需要先調用 wx.login 接口**
~~~
wx.getUserInfo({
success: function(res) {
var userInfo = res.userInfo
var nickName = userInfo.nickName
var avatarUrl = userInfo.avatarUrl
var gender = userInfo.gender //性別 0:未知、1:男、2:女
var province = userInfo.province
var city = userInfo.city
var country = userInfo.country
}
}
)
~~~
**設備
獲取網絡類型**
~~~
wx.getNetworkType({
success: function(res) {
var networkType = res.networkType // 返回網絡類型2g,3g,4g,wifi
}
})
~~~
**獲取系統信息(異步接口)**
~~~
wx.getSystemInfo({
success: function(res) {
console.log(res.model)
console.log(res.pixelRatio)
console.log(res.windowWidth)
console.log(res.windowHeight)
console.log(res.language)
console.log(res.version)
}
})
~~~
**撥打電話**
~~~
wx.makePhoneCall({
phoneNumber: '1340000' //僅為示例,并非真實的電話號碼
})
~~~
**獲取當前的地理位置、速度**
~~~
wx.getLocation({
type: 'wgs84',
success: function(res) {
var latitude = res.latitude
var longitude = res.longitude
var speed = res.speed
var accuracy = res.accuracy
}
})
~~~
## 隨手記
> 隨手記錄:const類似var
傳遞參數 在data{}中聲明參數,在onLoad里面去傳遞參數(賦值)
例:
~~~
data: {
pageNum:1
}
const _this=this
_this.setData({
pageNum:++_this.data.pageNum
})
~~~
- 關于我們
- ApiCloud
- 支付模塊
- 微信支付--wxPay(客戶端)
- 微信支付--wxPay(服務端)
- 支付寶支付--aliPay(客戶端配置)
- 支付寶支付--aliPay(服務端配置)
- DoT模板
- 緩存模塊
- 監聽模塊
- 百度定位模塊
- 設置狀態欄字體顏色
- 選擇城市插件
- 跨頁面執行方法
- 安卓-點擊返回事件
- 上傳圖片模塊
- 點擊彈出放大圖片層
- 魅族手機apiready問題
- 分享
- 跨win或frm執行腳本
- 關于ios數字自動識別成手機號
- 百度地圖bMap
- 語音識別模塊
- tabBarMenu底部導航
- 第三方登錄
- QQ網站和appQQ賬號的統一問題解決
- 微信登錄
- QQ登錄
- 微博登錄
- 上拉加載、下拉刷新模塊
- 圖片緩存
- 文件和圖片緩存機制分享
- PHP
- 支付寶及時到賬
- no input file specified報錯解決
- thinkphp 整合kindeditor
- 整合tpshop微信模塊到thinkcmf中
- thinkphp3.1.3整合支付寶
- 網站接入QQ OAuth2.0登錄教程
- ThinkPHP整合百度編輯器Ueditor
- PHP加快執行效率的寫法規范
- ThinkPHP操作大全
- PHP操作大全
- Thinkphp中SQL操作返回值
- php5.3 foreach 使用&(與運算符)引用賦值要注意的問題
- mysql給字段追加值
- 阿里大魚短信平臺接入
- Navicat 導出 Mysql 數據字典
- php 面向對象全面教程
- PHP5下調用SOAP
- PHP處理時間格式添加空格
- 偽裝URL請求(.htaccess)
- url請求參數加解密
- JS插件
- artDialog彈窗-頁面傳值
- jQuery點擊遮罩彈出層固定居中
- jeBox原生彈窗
- bxslider輪播
- js生成指定位數隨機數
- 發送短信倒計時
- js調試
- jQuery.validator 表單驗證規則
- Swiper 輪播
- 獲得焦點時-圖片抖動
- uploadify無刷新上傳圖片
- 導航下拉隱藏上拉顯示
- 獲得焦點時-加黑色蒙版
- jquery.qrcode.js生成二維條形碼(支持中文)
- jquery.qrcode.js生成二維條形碼(官方不支持中文)
- nth-child 選擇器
- 無刷新點擊實現加載更多數據
- 刷新頁面方法
- 判斷滾動條向上向下
- 跨瀏覽器復制jQuery-zclip
- js校驗表單后提交表單的三種方法
- 用JS判斷下拉框是否選中
- div中滾動
- 提交時彈出模態框
- 當圖片不顯示時替換方法
- 前端
- CSS3
- HTML5
- css技巧
- 移動端rem
- Flex布局
- 電商詳情滾動條監聽
- VueCircleMenu圓環按鈕
- iframe自適應頁面高度
- 百度Echart
- input:radio改變選中顏色
- Jquery
- 響應式布局基本實現Media Query
- 循環輸出只輸出新內容
- 小程序
- wx.request坑
- 概要
- git操作
- 本地記住密碼
- 操作
- 生成ssh公鑰 記住密碼
- git避坑
- ES6學習手札
- 調試小插件
- 谷歌插件Postman
- PHP調試助手
- WordPress
- 緩存服務器Redis
- 在線代碼運行 Docker
- 在ubuntu下怎樣安裝https
- BrowserSync 瀏覽器同步測試工具
- getmarkman高效的設計稿標注、測量工具
- PHPstrom軟件
- 服務器
- linux 安裝搭建服務器配置及nginx配置
- tpshop的nginx 服務器配置方法
- (服務器訪問文件404解決辦法)IIS 之 添加MIME擴展類型及常用的MIME類型列表
- mysql部分
- mysql緩存
- MySql監控工具--mytop
- MySql主從搭建
- mysql優化
- Mysql 復制 (主從復制)
- iOS開發筆記 - 上線流程
- VUE避坑指南
- 從零開始學Vue
- Vue-cli
- Webpack
- VUE小記
- npm打包空白
- 打包背景圖片/項目圖片不顯示
- VUE避坑指南/elementUI upload 自定義http-request上傳
- 關于watch監聽路由重復加載方法
- 解決加載內容的時候閃動問題
- vuecli沒有network訪問地址
- python學習
- python初始
- pytho內置函數大全
- win10 播放器播放TS文件問題
- 設計網站
- VUE避坑指南/VUE-CLI部署空白
- swiper使用問題
- uni-app學習手冊
- 目錄結構
- layUI
- nodesass版本sassloader版本問題