微信小程序框架解析

What?

  • 基于微信
  • 類web
  • 原生體驗
  • 解決方案

How?

交互原理

邏輯層(App Service)

  • 邏輯層由JavaScript編寫
  • 邏輯層將數(shù)據(jù)進行處理后發(fā)送給視圖層,同時接受視圖層的事件反饋
  • 所有代碼將會打包成一份JavaScript,啟動時運行,直到小程序銷毀

視圖層(View)

  • 由WXML與WXSS編寫,由組件進行展示
  • 將邏輯層的數(shù)據(jù)反應成視圖,同時將視圖層的事件發(fā)送給邏輯層。

App Service -Manager

  • App() -小程序入口
  • Page() -頁面入口
  • 數(shù)據(jù)綁定、事件分發(fā)、生命周期、路由管理
wxml
js

生命周期

Paste_Image.png

View - WXML

  • weixin markup Language
  • 支持邏輯、算數(shù)計算
  • 支持模板、引用

WXML ---compiler--->JS:generateFunc ---Data--->VirtualTree ----Virtual DOM--->Dom Tree


WXML 具有什么能力?

  • 數(shù)據(jù)綁定
<!-- wxml -->
<view> {{ message }}</view>
  • 列表渲染
<!--wxml-->
<view wx:for="{{array}}"> {{item}} </view>
  • 條件渲染
<!--wxml-->
<view wx:if="{{view == 'WEBVIEW'}}"> WEBVIEW </view>
<view wx:elif="{{view == 'APP'}}"> APP </view>
<view wx:else="{{view == 'MINA'}}"> MINA </view>
  • 模板
<!--wxml-->
<template name="staffName"> <view> FirstName: {{firstName}}, LastName: {{lastName}} </view></template>
<template is="staffName" data="{{...staffA}}"></template>
<template is="staffName" data="{{...staffB}}"></template>
<template is="staffName" data="{{...staffC}}"></template>
  • 事件
<view bindtap="add"> {{count}} </view>

page.js


Page({
 data: { 
  message: 'Hello MINA!',
  array: [1, 2, 3, 4, 5],
  view: 'MINA',
  staffA: {firstName: 'Hulk', lastName: 'Hu'}, 
  staffB: {firstName: 'Shang', lastName: 'You'},
  staffC: {firstName: 'Gideon', lastName: 'Lin'}
  count: 1
 },
 add: function(e) {
   this.setData({ count: this.data.count + 1 }) 
 }
})

View - WXSS

  • WXSS -weixin style sheet
  • 自適應單位 RPX-Responsive Pixel
  • 無級聯(lián)-避免被組件內(nèi)結(jié)構(gòu)破壞

WXSS -------compiler-----> JS -----width,DPR------> CSS

View -Render

  • 數(shù)據(jù)(Modal)與視圖(View)完全分離
  • 邏輯層運行在獨立環(huán)境中,無法直接操作DOM
  • 使用WXML模板語言減少維護成本
  • 單項數(shù)據(jù)綁定
  • 重渲染使用Virtual-DOM減少開銷
與Natice通信圖示
打包
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • WXML WXML(WeiXin Markup Language)是微信的一套標簽語言,結(jié)合基礎(chǔ)組件、事件系統(tǒng),可...
    許劍鋒閱讀 7,289評論 3 51
  • 微信小程序在無論在功能、文檔及相關(guān)支持方面,都是優(yōu)于前面幾種微信賬號類型,它提供了很多原生程序才有的接口,使得我們...
    未央大佬閱讀 2,397評論 0 12
  • 昨天看了一下微信小程序官方文檔,總結(jié)一下自己學習的個人心得. 首先從官方文檔給的框架說起,微信小程序官方文檔給出了...
    Mr大大大閱讀 47,514評論 9 68
  • 成為配得上希望的那個人 當你嘗試著進步的時候,你遇到的更可能是打擊而不是鼓勵··· “相信我 你并不孤單” 證明自...
    亮亮_412閱讀 191評論 0 0
  • 今晚的夜 美得窒息 漫天繁星 明月閃耀 它偷偷的進入 人們的 夢鄉(xiāng) 帶著人們 去尋找 神秘的國度
    DJ姑娘閱讀 126評論 0 0

友情鏈接更多精彩內(nèi)容