写几行代码,了解响应式原理

yizhihongxing
作者:袁首京

原创文章,转载时请保留此声明,并给出原文连接。

作为当下的开发人员,无论是不是前端,可能都会频繁的与 React、Vue、Svelte、Solidjs 等等打交道。也许你已经很清楚它们背后的运作原理,那不必往下看了。如果还不是很清楚,那咱们可以一起写几行代码,来瞅一眼这些响应式框架背后的思路。

响应式框架最根本的功能其实只有一条:当数据发生变化时,让界面随之发生变化

如何达成这一点呢?粗略的想一下就会觉得,首先要在数据和与之对应的 HTML 元素之间建立绑定关系。可以以某种方式给特定的 HTML 元素打个标记,然后当与此元素相关的值发生变更时,我们就能通过这个标记找到此元素,然后动态的改变它展示出来的值。

比如如下 HTML 模板片断:

<p>{{ current_time }}</p>

我们可以定义一个模板编译函数:

function compile(tpl) {
  const re = /(\{\{\s+)(\w+)(\s+\}\})/m;
  const mg = tpl.match(re);
  return tpl.replace(">{{", ' vid="' + mg[2] + '">{{').replace(mg[0], "");
}

执行该函数,就会给相关元素打上 vid 标记:

> compile('<p>{{current_time}}</p>')
<p vid="current_time"></p>

这样如果需要,我们就可以很方便的找到页面上需要响应的元素:

const vel = document.querySelector("[vid=current_time]");

接下来是数据部分。如何监测数据的变化呢?一种方案是使用代理。假如我们有如下数据对象:

{
  current_time: "2023-05-03T05:14:46.176Z";
}

可以使用如下函数,为其生成一个代理,拦截其赋值操作:

function reactive(data) {
  return new Proxy(data, {
    set(target, property, value) {
      const prev = target[property];
      target[property] = value;

      if (prev !== value) {
        const vel = document.querySelector(`[vid=${property}]`);
        vel.innerHTML = value;
      }

      return true;
    },
  });
}

接下来,就可以面向数据编程了:

const data = reactive({
  current_time: "2023-05-03T05:14:46.176Z",
});

setInterval(() => {
  data.current_time = new Date().toISOString();
}, 1000);

最终效果如下:

写几行代码,了解响应式原理

以下是完整代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <div id="root"></div>
    <script>
      function compile(tpl) {
        const re = /(\{\{\s+)(\w+)(\s+\}\})/m;
        const mg = tpl.match(re);
        return tpl.replace(">{{", ' vid="' + mg[2] + '">{{').replace(mg[0], "");
      }

      function reactive(data) {
        return new Proxy(data, {
          set(target, property, value) {
            const prev = target[property];
            target[property] = value;

            if (prev !== value) {
              const vel = document.querySelector(`[vid=${property}]`);
              vel.innerHTML = value;
            }

            return true;
          },
        });
      }

      const app = {
        tpl: "<p>{{ current_time }}</p>",

        data: {
          current_time: "2023-05-03T05:14:46.176Z",
        },

        mount() {
          const rootEl = document.querySelector("#root");
          rootEl.innerHTML = compile(this.tpl);

          this.data = reactive(this.data);

          this.mounted();
        },

        mounted() {
          setInterval(() => {
            this.data.current_time = new Date().toISOString();
          }, 1000);
        },
      };

      document.addEventListener("DOMContentLoaded", () => {
        app.mount();
      });
    </script>
  </body>
</html>

原文链接:https://www.cnblogs.com/rockety/p/17369256.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:写几行代码,了解响应式原理 - Python技术站

(0)
上一篇 2023年4月30日
下一篇 2023年5月4日

相关文章

  • 分享一款超好用的JavaScript 打包压缩工具

    下面是分享一款超好用的JavaScript打包压缩工具的完整攻略。 一、背景介绍 在前端开发中,我们经常需要使用JavaScript打包压缩工具来减小文件大小,提高网站的性能。本篇攻略将会介绍一款超好用的JavaScript打包压缩工具,并给出两个示例说明。 二、工具介绍 本文介绍的打包压缩工具是Webpack,它是现代化的 JavaScript 应用程序的…

    JavaScript 2023年5月27日
    00
  • 用户注册常用javascript代码

    下面是详细讲解“用户注册常用JavaScript代码”的攻略。 JavaScript代码说明 在用户注册界面,常用的JavaScript代码包括表单验证、密码强度检查和数据存储。 表单验证 表单验证是用户注册中必不可少的一部分,其目的是避免用户输入无效、错误或不想要的信息。常用的表单验证方法有以下几种: required属性:该属性用于添加必填项标记。 正则…

    JavaScript 2023年6月10日
    00
  • javascript的函数劫持浅析

    JavaScript的函数劫持指的是通过改变函数的执行环境,来获得对函数执行结果的控制。这个技术通常使用在针对其他人编写的代码,来改变目标代码的行为。下面是对JavaScript函数劫持的完整攻略: 什么是函数劫持? 函数劫持是指改变JavaScript函数的行为,使其执行方式符合我们的意愿。攻击者能够通过利用函数劫持的技术,在运行时改变目标函数的功能和输出…

    JavaScript 2023年5月27日
    00
  • Javascript延迟执行实现方法(setTimeout)

    下面是关于Javascript延迟执行实现方法(setTimeout)的详细讲解。 简介 JavaScript中的setTimeout()方法是用于在一定时间后执行指定的函数或一段代码。常用于实现延迟执行、定时器等功能。 语法格式 setTimeout(function, milliseconds, arg1, arg2, …); function:必需…

    JavaScript 2023年5月27日
    00
  • JS将指定的某个字符全部转换为其他字符实例代码

    下面是完整的攻略,包含了示例代码和说明: 思路: 我们可以通过JS的字符串处理方法,将指定字符串中的某个字符全部替换为其他字符。具体而言,我们可以使用字符串的replace()函数实现替换功能,该函数接受两个参数,分别表示要替换的字符和用于替换的字符。 下面是基本的replace()函数语法: str.replace(searchValue, replace…

    JavaScript 2023年5月28日
    00
  • JS AJAX前台如何给后台类的函数传递参数

    JS AJAX(Asynchronous JavaScript and XML)使得前端能够异步发起HTTP请求,获取数据,并更新页面,而无需刷新整个页面。在传递参数方面,AJAX提供了多种方式: 通过URL传递参数 通过在URL后面添加查询字符串,即可将参数传递给后台。 let xhr = new XMLHttpRequest(); let url = &…

    JavaScript 2023年6月11日
    00
  • 理解JavaScript中的事件

    下面是详细讲解“理解JavaScript中的事件”的完整攻略。 什么是事件? 事件是指用户在网页上进行操作时,浏览器自动识别的行为,比如鼠标的点击、移动,键盘的按下、松开等。JavaScript中的事件是指用户在网页上的操作行为,我们可以通过JavaScript代码来定义这些操作行为,让网页在用户进行某些操作时自动触发代码来实现一些特定的功能。 JavaSc…

    JavaScript 2023年6月10日
    00
  • JS正则表达式详解及身份证号码验证(简易版)

    JS正则表达式详解及身份证号码验证(简易版)是一篇详细讲解JavaScript的正则表达式和如何使用正则表达式去验证身份证号码的文章。本文主要分为以下几个部分: 正则表达式入门基础 本部分主要介绍正则表达式的基本概念和常用语法。 正则表达式是一组特殊字符和字符序列,组成规则是通过这些字符和序列来描述文本模式。比如,我们可以使用正则表达式来搜索特定模式的文本,…

    JavaScript 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部