把数据搞到页面上展示

简介: 根据上文提到了数据响应式的实现,这次我们再一次升级,模仿vue框架,实现这些响应式数据渲染到页面中。

网络异常,图片无法展示
|


根据上文提到了数据响应式的实现,这次我们再一次升级,模仿vue框架,实现这些响应式数据渲染到页面中。


原始的Vue用法:

网络异常,图片无法展示
|


接下来写一个我们自己的简版DVue。

根据 从设计理念到数据响应式一文,我们先来实现data中响应式数据的获取。


数据代理


从图片中可以看出,通过new 一个Vue实例,拿到data中的数据。访问格式为vm.name


首先,自己创建一个DVue文件,在页面中引入。以下与逻辑操作有关的代码均是在DVue中。


我们需要创建一个DVue类,通过构造函数获取传入的参数。在内部对data中的数据进行拦截监听。但是我们访问vm.name是没有输出的(undefined)。因为我们对DVue只是进行了响应拦截,并没有对其进行代理

class DVue {
  constructor(options) {
    this.$options = options
    this.$data = options.data
    console.log(this.$data)
    observe(this.$data)
    proxy(this) // 代理
  }
}


那么我们就需要去实现这个代理的功能函数。将拿到的this.$data变量中的键值进行遍历(Object.keys),分别将其代理到实例上。其数据一定也是响应式的。


function proxy(vm) {
  Object.keys(vm.$data).forEach((key) => {
    Object.defineProperty(vm, key, {
      get() {
        return vm.$data[key]
      },
      set(newVal) {
        if (newVal != vm.$data[key]) vm.$data[key] = newVal
      },
    })
  })
}


编译响应式数据


当然,啥也没写就是这样的。。。

网络异常,图片无法展示
|


今天咱们就把数据替换到页面上。


在做好数据的响应式及代理之后,我们又一重要的环节要来了:编译!


看过原理的同学都知道,负责编译的就是Compile这个类。在DVue类中执行编译(new Compile(options.el, this)),将当前dom和实例传入。

class Compile {
  constructor(el, vm) {
    this.$vm = vm
    let dom = document.querySelector(el)
    this.compiler(dom)
  }
  compiler(el) {
    const childNodes = el.childNodes
    childNodes.forEach((node) => {
      if (isNode(node)) {  // 元素
        if (node.childNodes.length > 0) this.compiler(node)
      } else if (isTextNode(node)) {  // 文本
        console.log('编译插值', node.textContent, this.$vm[RegExp.$1])
        this.compileText(node)
      }
    })
  }
  compileText(node) {
    node.textContent = this.$vm[RegExp.$1]
  }
}
function isNode(el) {
  return el.nodeType === 1
}
const defaultTagRE = /\{\{((?:.|\r?\n)+?)\}\}/ //{{ 值 }}
function isTextNode(el) {
  return el.nodeType === 3 && defaultTagRE.test(el.textContent)
}


在Compile中,循环遍历#app下面的子节点。可能会遇到子节点是文本或是元素的情况,至此我们就需要将两种情况分开。


  • 文本节点。直接将节点的textContent属性替换即可。
  • 元素节点。里面可能存在元素嵌套元素这样的可能。所以我们需要判断当前元素节点的子元素个数(node.childNodes.length > 1),如果里面还存在子元素。就需要将其递归在进行下层解析。


这边可能还有一点难理解的可能就是正则。对于此我也不是特别熟悉,这边我是参考的源码中的正则获取到的{{ 值 }}的值。当然源码中使用的是exec方法进行的匹配判断。具体exec方法使用可以参考这里。有的时候使用exec方法是不能立即起作用的,需要手动的重启以下,具有一定的延迟性。

网络异常,图片无法展示
|

结合上篇文章,我们已经完成了上图的两大模块:Observer的数据劫持、Compile的初始化视图。


简单的数据在页面中展示到此就完成拉。感兴趣的可以关注 Vue源码初识专栏,会持续输出vue相关知识哦(●'◡'●)。 如果不足,请多指教。

目录
相关文章
|
4月前
|
前端开发
【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】
本文档详细介绍了CSS中清除默认样式的方法,包括清除内外边距、列表项目符号等;探讨了外边距的合并与塌陷问题及其解决策略;讲解了行内元素垂直边距的处理技巧;并介绍了圆角与盒子阴影效果的实现方法。最后通过产品卡片和新闻列表两个综合案例,展示了所学知识的实际应用。
87 11
图库,设计类软件,App视频截图软件,外加设计图库,在你截取视频就能够实现图片收录,通过设计类网站后台控制系统,可以提前设置好,统计的分类内容,定义好分类,自动收录图片,再将截图汇总整理展示
图库,设计类软件,App视频截图软件,外加设计图库,在你截取视频就能够实现图片收录,通过设计类网站后台控制系统,可以提前设置好,统计的分类内容,定义好分类,自动收录图片,再将截图汇总整理展示
图库,设计类软件,App视频截图软件,外加设计图库,在你截取视频就能够实现图片收录,通过设计类网站后台控制系统,可以提前设置好,统计的分类内容,定义好分类,自动收录图片,再将截图汇总整理展示
|
前端开发 JavaScript
【项目笔记】:elementui下拉框数据太多造成页面卡顿怎么解决?
针对前端下拉框数据过多造成页面卡顿,元芳你怎么看?
280 2
|
存储 小程序 前端开发
【易售小程序项目】小程序私聊页面完善(带尾巴聊天气泡组件封装、滑至顶端获取历史聊天数据逻辑优化)【后端基于若依管理系统开发】
【易售小程序项目】小程序私聊页面完善(带尾巴聊天气泡组件封装、滑至顶端获取历史聊天数据逻辑优化)【后端基于若依管理系统开发】
74 0
|
SQL XML 前端开发
怎么做社区网站的首页帖子展示?
要进行首页帖子展示,就必须学会分页,而在创建分页之前,我们得先认识到,为什么要进行分页?一个大型网站的数据库将容纳大量的数据,而我们进行展示某部分数据时,为了保证浏览速度,不可能一次性地将所有数据进行传输,更何况,不是全部传输过去的数据第一时间就能有效利用,所以,只要每次将需要的数据传输过去就好,即使是后续需要的数据,那也是后面时间点需要完成的工作,为了做到这一点,必须对一个数据整体进行划分,合理地传输并展示给用户,其中,划分出来的每一部分可被称为一页数据,完成划分工作的就是分页操作。而分页操作在 spingboot 及 mybatis 的环境下,可被分为以下几种分页情况:
152 0
|
数据可视化 开发工具 git
只会Excel想做图表可视化,让数据动起来?可以,快来围观啦(附大量模板下载)
只会Excel想做图表可视化,让数据动起来?可以,快来围观啦(附大量模板下载)
|
前端开发
A2021-A2022项目展示页面的内容。
A2021-A2022项目展示页面的内容。
110 0
A2021-A2022项目展示页面的内容。
|
移动开发 前端开发 IDE
「趣学前端」日常浏览的页面是怎么实现出来的
用技术实现梦想,用梦想打开创意之门。为了给不懂技术的朋友讲解日常开发中怎么实现网页的效果,我准备出一个系列。
147 1
|
前端开发
前端工作小结68-页面数据不显示
前端工作小结68-页面数据不显示
106 0
前端工作小结68-页面数据不显示
|
JSON 前端开发 JavaScript
列表展示怎么做
列表展示怎么做
114 0

热门文章

最新文章