>웹 프론트엔드 >JS 튜토리얼 >WeChat 미니 프로그램 프런트엔드 소스 코드 로직 및 워크플로우 분석

WeChat 미니 프로그램 프런트엔드 소스 코드 로직 및 워크플로우 분석

hzc
hzc앞으로
2020-07-03 11:21:323052검색

WeChat 애플릿의 프런트 엔드 코드를 읽은 후 정말 피가 끓었습니다. 코드 논리와 디자인이 한눈에 명확하고 불필요한 것이 없으며 정말 간단합니다.

더 이상 고민하지 않고 프런트엔드 코드를 직접 분석해 보겠습니다. 개인적인 의견이라 누락된 부분이 있을 수 있으니 참고용으로만 사용하세요.

파일의 기본 구조:

먼저 app.js 입구를 보면 app(obj)가 작은 프로그램을 등록합니다. 애플릿의 수명주기 기능 등을 지정하는 객체 매개변수를 허용합니다. 다른 파일은 전역 메서드 getApp()을 통해 앱 인스턴스를 얻은 다음 (getApp().globalData)

//app.jsApp({
  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
  }
})

와 같은 해당 속성이나 메서드를 직접 호출할 수 있습니다. app.js가 항목 초기화 파일이고 또한 글로벌 API 확장 장소를 제공합니다. 내장된 몇 가지 메소드와 속성을 분석해 보겠습니다.

onLaunch 후크 함수는 미니 프로그램이 초기화된 후 한 번 자동으로 실행됩니다. 그러면 미니 프로그램 수명 주기 동안 onLaunch를 적극적으로 호출하지 않으면 실행되지 않습니다. 실행.

var logs = wx.getStorageSync('logs') || []
获取本地缓存中的logs属性,如果值为空,那么设置logs=[] 与HTML5中的localStorage作用相似

logs.unshift(Date.now()) 当前登录时间添加到数组中

wx.getStorageSync('logs')获取本地缓存数据

getUserInfo 함수는 이름에서 알 수 있듯이 로그인한 사용자 정보를 가져오는 기능입니다. 이 함수는 호출되지 않으면 다른 페이지가 실행되지 않습니다. 다른 페이지에서는 getApp().getUserInfo(function(userinfo){console.log(userinfo);})를 통해 이 메서드를 호출하여 사용자 정보를 얻습니다.

getUserInfo:function(cb){//参数为cb,类型为函数
    var that = this
    if(this.globalData.userInfo){//用户信息不为空
      typeof cb == "function" && cb(this.globalData.userInfo)//如果参数cb的类型为函数,那么执行cb,获取用户信息;
    }else{//如果用户信息为空,也就是说第一次调用getUserInfo,会调用用户登录接口。      wx.login({
        success: function () {
          wx.getUserInfo({
            success: function (res) {
         console.log(res)
              that.globalData.userInfo = res.userInfo//把用户信息赋给globalData,如果再次调用getUserInfo函数的时候,不需要调用登录接口
              typeof cb == "function" && cb(that.globalData.userInfo)//如果参数cb类型为函数,执行cb,获取用户信息            }
          })
        }
      })
    }
  }

globalData 개체는 전역 데이터를 저장하는 데 사용되며 다른 곳에서 호출됩니다.

그런 다음 app.json 파일을 간략하게 분석합니다. 이 파일의 기능은 WeChat 애플릿을 전역적으로 구성하고 경로를 결정하는 것입니다. 페이지 파일 및 창 성능, 네트워크 시간 초과 설정, 여러 탭 설정 등

가장 중요한 것은 pages 속성입니다. 필수입니다. 배열이며, 배열의 요소는 문자열 파일 경로입니다. 미니 프로그램은 어떤 페이지로 구성되어 있는지, 첫 번째 항목은 미니 프로그램 초기 페이지여야 합니다.

{  "pages":[    "pages/index/index",    "pages/logs/logs"
  ],  "window":{    "backgroundTextStyle":"light",    "navigationBarBackgroundColor": "#fff",    "navigationBarTitleText": "WeChat",    "navigationBarTextStyle":"black"
  }
}

그런 다음 프로젝트 인덱스 및 로그 폴더를 살펴보세요. WeChat 애플릿의 초기 프로젝트에서는 각 페이지와 관련된 js, wxss, wxml을 자체 파일에 넣어 구조가 훨씬 명확해 보입니다.

먼저 미니 프로그램의 초기 페이지인 인덱스 폴더를 살펴보겠습니다. index 폴더 아래에는 index.js, index.wxml 및 index.wxss라는 세 개의 작은 파일이 있습니다. 미니 프로그램은 js, css, html 코드를 분리하여 별도의 파일에 넣어 각각 고유한 임무를 수행합니다. js 및 스타일시트 파일 이름은 현재 폴더의 wxml 파일 이름과 일치해야 js 및 스타일시트의 효과가 페이지에 표시될 수 있습니다. 깔끔하고 균일하며 책임이 명확하고 코드 디자인의 복잡성을 줄여주는 이런 종류의 디자인 컨셉에 감사드립니다.

index.wxml, 이는 프런트 엔드 mvc, mvvm을 사용하는 데이터 기반의 공통 템플릿 파일입니다. 프로젝트 개발자는 결국 이에 대해 잘 알고 있어야 합니다. react에서 개발했습니다.  

925a1f3a4f482e42fdef638109e2ed51
8f757650f3432f76274b21f6b4c1fc9a//视图容器
  6669428ff968f9fab7cc4603253a5a2b
  //bindtap为容器绑定点击触摸事件,在触摸离开时触发bindViewTap事件处理函数,bindViewTap通过index.js page()设置添加
    3d048a2b9ff2c224f697c32c3f24dc4ef8e950ebc6c1ea27f76cf997b9216fe6
    //大双括号的变量来自于index.js的data对象解析成对应的值,而且是实时的
    277932af4e9676f3c247b090853cb2a7{{userInfo.nickName}}273e21371c5d5e701d3c98517a0bfa41
  de5f4c1163741e920c998275338d29b2
  a675b38a74d9bf96543e9ed6fb1ac95e
    2602ac4605743953d5d7d0fd8c968325{{motto}}273e21371c5d5e701d3c98517a0bfa41
  de5f4c1163741e920c998275338d29b2
de5f4c1163741e920c998275338d29b2

index.js, 사용법은 reaact와 거의 동일합니다. 약을 바꾸지 않고 수프를 바꾸는 것입니다. page() 페이지를 등록합니다. 페이지의 초기 데이터, 수명 주기 기능, 이벤트 처리 기능 등을 지정하는 OBJECT 매개변수를 허용합니다.

var app = getApp() // 获取入口文件app的应用实例Page({
  data: {
    motto: 'Hello World',
    userInfo: {}
  },  //自定义事件处理函数,点击.userinfo的容易触发此函数
  bindViewTap: function() {
    wx.navigateTo({//全局对象wx的跳转页面方法
      url: '../logs/logs'
    })
  },
  onLoad: function () {//发生页面加载时,自动触发该生命周期函数
    console.log('onLoad')    var that = this
    //调用应用实例的方法获取全局数据
    app.getUserInfo(function(userInfo){      //更新数据,页面自动渲染      that.setData({
        userInfo:userInfo
      })
    })
  }
})

index.wxss 파일은 현재 페이지만 렌더링하며 전역 app.wxss와 동일한 스타일을 덮어씁니다.

그런 다음 logslog 폴더를 분석하면 logs 폴더는 logs.wxml, logs.j 로그 . wxss, logs.json, 마찬가지로 효과 렌더링을 완료하려면 이름이 동일한지 확인하세요.

logs.wxml 파일

<!--logs.wxml-->
<view class="container log-list">
  <block wx:for="{{logs}}" wx:for-item="log">
  //block容器作用,无其他实际含义。wx:for作用:遍历logs数组,遍历多少次,block块就会复制多少次,for-item等同于为
      遍历元素起一个变量名,方便引用。
    <text class="log-item">{{index + 1}}. {{log}}</text>
  </block>
</view>

logs.js 파일

//logs.js
var util = require(&#39;../../utils/util.js&#39;) 
//util.js相当于一个函数库,我们可以在这个文件内自定义扩展和封装一些常用的函数和方法
Page({
  data: {
    logs: []
  },
  onLoad: function () {
    this.setData({
      logs: (wx.getStorageSync(&#39;logs&#39;) || []).map(function (log) {
      //通过wx.getStorageSync获取本地缓存的logs日志数据
        return util.formatTime(new Date(log))//日期格式化
      })
    })
  }
})

logs.json 파일

{
   "navigationBarTitleText": "查看启动日志"   //当前页面配置文件,设置window当前页面顶部导航栏标题等相关内容
} 

基本页面结构和逻辑就这么简单,暴露给我们的没有一点令人费解的东西。

小程序还提供了很多官方组件和API等待我们深挖,加油吧,少年!小程序官方文档地址

推荐教程:《微信小程序

위 내용은 WeChat 미니 프로그램 프런트엔드 소스 코드 로직 및 워크플로우 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
이전 기사:js 호출 사용법다음 기사:js 호출 사용법