小程序模板網(wǎng)

微信小程序開發(fā)注意事項,實現(xiàn)機制,開發(fā)前須知,路由,Tab頁,頁面結(jié)構(gòu) .

發(fā)布時間:2018-03-28 14:58 所屬欄目:小程序開發(fā)教程

第一部分:開發(fā)注意事項:

顏色限制

  1. navigationBarTextStyle 導(dǎo)航欄標(biāo)題顏色僅支持 black/white
  2. backgroundTextStyle 下拉背景字體、loading 圖的樣式,僅支持 dark/light
  3. borderStyle tabbar上邊框的顏色, 僅支持 black/white

程序限制

  1. 腳本內(nèi)不能使用window等對象
  2. zepto/jquery 會使用到window對象和document對象,所以無法使用。
  3. 樣式表不支持級聯(lián)選擇器
  4. 本地資源無法通過 css 獲取 background-image:可以使用網(wǎng)絡(luò)圖片,或者 base64,或者使用標(biāo)簽
  5. 不支持 A 標(biāo)簽,無法打開普通網(wǎng)頁

數(shù)量限制

  1. 底部或頂部可以添加tab按鈕區(qū)域 tabBar 是一個數(shù)組,只能配置最少2個、最多5個 tab,tab 按數(shù)組的順序排序。
  2. 一個應(yīng)用同時只能打開5個頁面

大小限制

  1. tabBar 上面的按鈕 iconPath 圖片路徑,icon 大小限制為40kb
  2. tabBar 上面的按鈕 selectedIconPath 選中時的圖片路徑,icon 大小限制為40kb
  3. setData 頁面?zhèn)鬟f數(shù)據(jù)單次設(shè)置的數(shù)據(jù)不能超過1024kB
  4. setStorage 本地緩存最大為10MB
  5. 小程序源碼打包后的大小限制為1M

消息限制

  1. 支付當(dāng)用戶在小程序內(nèi)完成過支付行為,可允許開發(fā)者向用戶在7天內(nèi)推送有限條數(shù)的模板消息(1次支付可下發(fā)1條,多次支付下發(fā)條數(shù)獨立,互相不影響)
  2. 提交表單 當(dāng)用戶在小程序內(nèi)發(fā)生過提交表單行為且該表單聲明為要發(fā)模板消息的,開發(fā)者需要向用戶提供服務(wù)時,可允許開發(fā)者向用戶在7天內(nèi)推送有限條數(shù)的模板消息(1次提交表單可下發(fā)1條,多次提交下發(fā)條數(shù)獨立,相互不影響)

審核說明

標(biāo)題

  1. 標(biāo)題不能存在相同
  2. 標(biāo)題意思不能存在過度相似
  3. 標(biāo)題必須以“提醒”或“通知”結(jié)尾
  4. 標(biāo)題不能帶特殊符號、個性化字詞等沒有行業(yè)通用性的內(nèi)容
  5. 標(biāo)題必須能體現(xiàn)具體服務(wù)場景
  6. 標(biāo)題不能涉及營銷相關(guān)內(nèi)容,包括不限于:消費優(yōu)惠類、購物返利類、商品更新類、優(yōu)惠券類、代金券類、紅包類、會員卡類、積分類、活動類等營銷傾向通知

關(guān)鍵詞

  1. 同一標(biāo)題下,關(guān)鍵詞不能存在相同
  2. 同一標(biāo)題下,關(guān)鍵詞不能存在過度相似
  3. 關(guān)鍵詞不能帶特殊符號、個性化字詞等沒有行業(yè)通用性的內(nèi)容
  4. 關(guān)鍵詞內(nèi)容示例必須與關(guān)鍵詞對應(yīng)匹配
  5. 關(guān)鍵詞不能太過寬泛,需要具有限制性,例如:“內(nèi)容”這個就太寬泛,不能審核通過

違規(guī)說明

除不能違反運營規(guī)范外,還不能違反以下規(guī)則,包括但不限于:

  1. 不允許惡意誘導(dǎo)用戶進行觸發(fā)操作,以達到可向用戶下發(fā)模板目的
  2. 不允許惡意騷擾,下發(fā)對用戶造成騷擾的模板
  3. 不允許惡意營銷,下發(fā)營銷目的模板
  4. 不允許通過服務(wù)號下發(fā)模板來告知用戶在小程序內(nèi)觸發(fā)的服務(wù)相關(guān)內(nèi)容

處罰說明

處罰結(jié)果及原因以站內(nèi)信形式告知
根據(jù)違規(guī)情況給予相應(yīng)梯度的處罰,一般處罰規(guī)則如下:

  1. 第一次違規(guī),刪除違規(guī)模板以示警告,
  2. 第二次違規(guī),封禁接口7天,
  3. 第三次違規(guī),封禁接口30天,
  4. 第四次違規(guī),永久封禁接口
 
第二部分:實現(xiàn)機制及其他

一 、小程序是什么?

  • 一種介于原生app、和web app的hybrid, 比web app 的開發(fā)成本還低;
  • 通過微信進行加載;
  • 相對原生app來說,更加輕量、更新實時、跨平臺;
  • 相對web app來說,資源離線,體驗更流暢。
  • 可以使用微信的支付功能

二 、實現(xiàn)機制

基于微信提供的一套應(yīng)用框架。微信通過封裝微信客戶端提供的文件系統(tǒng)、網(wǎng)絡(luò)通信、任務(wù)管理、數(shù)據(jù)安全等基礎(chǔ)功能,對上層提供了一套完整的Javascript Api,開發(fā)者能夠非常方便的調(diào)用微信客戶端提供的各種基礎(chǔ)功能。

視圖層描述語言 .WXML 和 .WXSS,以及基于 JavaScript 的邏輯層框架,并在視圖層與邏輯層之間通過 單向數(shù)據(jù) 綁定進行數(shù)據(jù)傳輸



三 、開發(fā)前須知

  • AppStore問題;
  • 發(fā)布的項目包體積 < 1M, 只適合輕量級 ;
  • 開發(fā)基于微信框架,部分功能受限, 不能操作DOM, 沒有script標(biāo)簽,要引入則需加入項目文件夾;
  • 沒有與瀏覽器BOM相關(guān)的API;
  • 沒有cookie ;
  • 用 storage 替代了H5中的localstorage、sessionstorage、 storage對每個小程序的大小是 10M,支持 同步 和 異步 。
  • 同時只能存在 5 個url請求;
  • 小程序頁面只能同時打開 5 個,如果交互流程較長難以支持;
  • 注釋方式: // comment, /** comment **/;

注意:cookie問題,在請求發(fā)送時,可以動態(tài)設(shè)置Header發(fā)送報文的cookie,但是 cookie本身不能在客戶端進行讀寫。


wx.request({
    header: {cookie: "abcd1234"},
    url: "/getinfo",
    data: {},
    ...
})

四、路由
  1. pages 里面的第一個元素即為首頁;
  2. 每個頁面需要手動在app.json中進行注冊,否則不能訪問;
  3. 路由跳轉(zhuǎn): 組件跳轉(zhuǎn)(navigator) / API跳轉(zhuǎn)

wx.navigateTo({  // 保留當(dāng)前頁
    url: "",
    ...
}) 

wx.navigateTo({  // 關(guān)閉當(dāng)前頁
    url: "",
    ...
})


五、Tab頁
  1. 由app.json定義;
  2. 配置最少2個、最多5個;
  3. 每個頁面的 .json 文件可以覆蓋定義導(dǎo)航欄。
  4. 六、頁面結(jié)構(gòu)由同路徑下同名的四個不同后綴文件的組成:
  • .js 文件是腳本文件
  • .json 文件是配置文件
  • .wxss 是樣式表文件
  • .wxml 文件是頁面結(jié)構(gòu)文件



.wxml 文件



// wxml語法

<block wx:for="{{shareItems}}" wx:for-index="idx">
    <view id="{{idx}}" class="flex share-item box box-tb">
      <view class="flex box box-lr article-info">
        <view class="flex title">{{item.articleInfo.title}}</view>
      </view>
      <view class="user-info box box-lr">
        <image src="{{item.articleInfo.isApproved ? icon.approved : icon.approve}}" class="icon approve-icon"></image>
      </view>
    </view>
</block>
  1. .wxml 文件通過相同的名稱,將頁面與邏輯js、樣式、配置進行關(guān)聯(lián)匹配
  2. .wxml 組件語法
  3. .wxml 提供兩種文件引用方式import(有作用域)和include
  4. 事件綁定方式

// test.wxml

{{userName}}

// test.js

page({
    data: {},
    getInfo: function() {
        this.setData({
            userName: "Tom"
        })
    }
})


.wxss 文件

/** app.wxss **/

@import "common.wxss";

view {
  padding:15px;
}
  1. 可通過 @import (后跟相對路徑)樣式表;
  2. 尺寸單位:有兩種單位:(1)、引入rpx(根據(jù)屏幕寬度進行自適應(yīng))的概念; (2)、rem;
  3. 支持內(nèi)聯(lián)
  4. 選擇器:不再支持媒體查詢,支持 .demo, #demo, view, view input, view::after, view::before;
  5. 增加了app的flex布局;
  6. 目前還不支持動畫 ;
  7. weui 官方樣式庫

規(guī)定屏幕寬為750rpx, 如iPhone6, 1rpx = 1物理像素 = 0.5px;

規(guī)定屏幕寬度為20rem, 1rem = (750/20)rpx;


.js 文件

  1. 模塊運行(類似node,框架自動添加外層define);
  2. 形式上支持CommonJs,通過require加載;
  3. data應(yīng)約定為只讀,不能直接修改data值,否則 容易造成data中的數(shù)據(jù)與view不一致;
  4. 更新View需使用setData(),與data中的數(shù)據(jù)進行Diff比較,不同才會更新。

  • setData() 單次設(shè)置的數(shù)據(jù) < 1M,要避免一次設(shè)置過多的數(shù)據(jù);
  • 支持ES6中的 … 操作符展開模塊數(shù)據(jù)。


// js引入 

// a.js
function sayHi() {
    console.log("hello wxAPP!");
}
module.exports = {
    say: sayHi
}

// b.js
var say = require("a.js");

// data 操作 

page({
    data: {
        name: 'one'
    },
    handleData() {

        // 錯誤操作方式,雖不會報錯,但不會更新view
        this.data.name = 'two';

        // 正確操作方式
        this.setData({
            name: 'tow'
        })
    }
})
.json 文件
  • 各個頁面的配置性文件


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://www.u-renovate.com/wxmini/doc/course/22911.html 復(fù)制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢:800182392 點擊咨詢
QQ在線咨詢