IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 构建vue-like,在原生小程序中使用 API并支持(一) -> 正文阅读

[JavaScript知识库]构建vue-like,在原生小程序中使用 API并支持(一)

在原生小程序中使用VUE写法并支持(一)

前言

在之前我使用了defineProperty来构建了一个简单的vue-watch-like式监听属性,但是defineProperty的缺点也是显而易见的,它无法深度监听数组的变化,当数组长度被修改时或其他意外行为时,defineProperty无法准确监听到数据变化。
这一章我利用ES6中的proxy来从新写一个监听属性,并且不止于此,我打算构建成一个小程序中的vue-like框架。

相关资料
Proxy-MDN
defineProperty-MDN

目标

构建一个小程序中的vue-like框架,使得使用这个库后可以让我们的前端人员在写原生小程序时,就跟写vue代码类似,可以使用相同的API并达到相同效果。
话不多说,开始。

第一步-解决setData

小程序中,渲染机制由setData触发,如果没有调用setData,即时改变了data中的值,页面也不会重新渲染,这点跟react很相似,react使用setState,而在vue中,单纯的给data中的属性赋值就会重新渲染页面,所以我们第一步要做的,就是解决setData,让开发人员在开发过程中,对于页面的修改只需要修改data中属性的值,而不用setData。
首先我们构建一个类库,在构造时接受2个参数,1.ctx上下文对象,也就是小程序单页面的this,2.一个属性对象,也就是我们接下来需要在里面放置的vue-like-api,眼下我们先构建一个监听属性。

class QVue{
     // 构造函数,接受一个上下文,和对象,对象内放置vue-watch属性,后续加入更多
    constructor(ctx={},{watch={}}){
        this.ctx = ctx;
        this.watch = watch;
        
    }
}

在QVue中放置对应的函数。

class QVue{
     // 构造函数,接受一个上下文,和对象,对象内放置vue-watch属性,后续加入更多
    constructor(ctx={},{watch={}}){
        this.ctx = ctx;
        this.watch = watch;
        
    }
    
    // 初始化
    mounted=()=>{
    }
    // 监听者
    observer=()=>{
    }
}

在监听者中通过proxy包装上下文中的data,包装过后的data是一个Proxy对象,当内部属性发生变化时,会触发get、set函数。我们可以用get拿到我们的旧值并保存,通过set拿到修改后的值。通过这两个函数,我们就可以把页面中的setData简化,当页面进行this.data.num=1这类赋值时,set方法就会触发并接收该属性最新的值,我们通过ctx上下文的setData,在set中调用渲染。
到这里 ,我们的第一步解决setData就算完成了,在页面中只要data中的值有变化都会重新触发页面渲染。

class QVue{
     // 构造函数,接受一个上下文,和对象,对象内放置vue-watch属性,后续加入更多
    constructor(ctx={},{watch={}}){
        this.ctx = ctx;
        this.watch = watch;
        
    }
    
    // 初始化
    mounted=()=>{
    }
    // 监听者
    observer =(ctx,watch)=> {
        // 给data包装proxy
        ctx.data = new Proxy(ctx.data, {
          get: function (_obj, _key,) {
            this.oldValue = _obj[_key]
            return _obj[_key]
          },
          set: function (_obj, _key, newVal) {
            // 赋值,没有赋值的话proxy里的属性还是旧数据
            _obj[_key] = newVal
            // 使用setData自动更新视图
            ctx.setData({
              ...ctx.data,
            });
            return true;
          },
        });
      }
}

第二步-添加监听属性

这一步其实在上一章中就有实现,我们已经在第一步中包装了上下文的data并且监听到了每个属性的修改变动,那么下一步就是在监听到的时间中,调用传入的watch对象中的对应函数,并且把新值与旧值传递过去。

class QVue {
     // 构造函数,接受一个上下文,和对象,对象内放置vue-watch属性,后续加入更多
    constructor(ctx={},{watch={}}){
        this.ctx = ctx;
        this.watch = watch;
        // 初始化
        this.mounted()
    }

    mounted=()=>{
        const {ctx,watch} = this;
        this.observer(ctx,watch)
    }
    // 监听者
    observer =(ctx,watch)=> {
        // 给data包装proxy
        ctx.data = new Proxy(ctx.data, {
          get: function (_obj, _key,) {
            this.oldValue = _obj[_key]
            return _obj[_key]
          },
          set: function (_obj, _key, newVal) {
            // 赋值,没有赋值的话proxy里的属性还是旧数据
            _obj[_key] = newVal
            // 给watch添加监听函数,当数据变化时,执行回调
            // 使用setData自动更新视图
            ctx.setData({
              ...ctx.data,
            },()=>{
              // 调用对应watch的回调,并传递秀新值与旧值
              watch[_key]&&watch[_key].call(ctx, newVal,this.oldValue)
            });
            return true;
          },
        });
      }
}

在页面中使用 How to use

import QVue from "/QVue";
Page({
data: {
    active: "",
  },
  
 /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
  // 在生命周期中使用,如果不需要监听属性,第二个参数可以不传
    new QVue(this, {
      watch: {
        active: function (newVal) {
          console.log('变化了,值是:',newVal);
          // 变化了,值是:0
        },
      },
    });
    this.active = 0
  },
})

未完待续…

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-08 10:37:59  更:2021-09-08 10:40:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 16:56:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码