前端随笔0:URL与状态的双向绑定
记录一些最近写前端的思考总结,也算是给自己的技术随笔开个篇
在接触以 React,Vue 为代表的工程化前端框架前,我还是一个拿着 jQuery 手撸特效和手写 CSS 的切图仔,捣鼓 Vue 时接触到的一个非常核心的概念就叫做“双向绑定”,这里的双向绑定指的是视图(template)与状态(state)的双向绑定,状态的变化直接触发组件的渲染,不需要手写控制和更新渲染的 js 函数了(没错这是我之前干的事)
这篇要讨论的这个概念,应该也不是我发明的新词,叫 URL 与状态的双向绑定,字面意思来说,在刷新页面或跳转页面时解析 URL 并对应更新组件的状态,在组件状态更新时同步更新 URL,为什么要引入这种机制嘞?
比如我目前在做的一个项目是一个管理后台,在一个非常典型的日志查询场景,可以选择和调整很多查询参数进行查询,但是由此就引出了一个问题,如果按照目前 Vue 双向绑定的写法,变更查询组件的状态(选择或输入参数等)不会反映到 URL 上,这时如果我需要将一组查询好的结果分享给同事,只能复制当前的页面链接给他,让他进入后再选择和我一样的查询参数,可以看到有一部分没有包含在 URL 中的信息其实是被丢弃掉了,另外在进行站内跳转时也无法跳转的更“具体”,只能跳转到 router 定义的页面在初始渲染完成后的样子
这就引入URL与状态双向绑定的好处了,比如我在日志查询页面中选择查询方法为 POST ,等级为 ERROR 的日志,监听组件对应的状态变更,并更新URL(假设为?method=POST&level=ERROR),同理适用于其他的变更
当然做到监听组件状态更新 URL 只是做到了双向绑定的一向,要想让你的同事真的恢复到你当前页面的状态还需要实现另一向的操作,即将 URL 解析到组件状态,往往是在页面组件 mount 时解析当前的 URL 路径与QueryString,将其中的参数解析出来并与组件的状态进行同步,事实上就实现了
URL ⇔ 组件状态 ⇔ 组件视图
带给用户的直观体验就是视图与 URL 的绑定,这时如果你将浏览器中的链接粘贴给同事,他在打开时就可以复现你当前的组件状态,进而得到你目前的视图界面了
总结一下,实现 URL 与状态的双向绑定其实就是需要实现
监听组件状态更新URL(通过 watch 或 $emit 等手段)
将 URL 解析到组件状态(如在组件 mount 时将 URL 参数解析并赋值给组件的 data 状态)
带来的好处有
分享链接可以让访问者完整复现当前页面的状态(至少是复现到你希望的粒度)
站内跳转可以随心所欲跳转到任何可能的状态(而且仅通过 URL 这种 Web 原生的方式,而非使用 Vuex 之类的状态管理)
这样的功能业界其实也已经有过一些开源库能够自动实现组件状态与 URL 查询参数的绑定,奈何自动化的方案给出的 URL 都太过冗余,而我在命名方面又是一个强迫症,秉承着奥卡姆剃刀原则,我还是手动实现了每个状态的绑定与解析,虽然较为机械化,但是往往就是在这种时候,我可以听着音乐哼着歌,以近乎肌肉记忆的状态有节律地敲打键盘,把这些不需要思考的代码写好
比起调 infra 里那些摇摆不定,反复横跳,此起彼伏的 bug,写前端,调界面逐渐变成了一件放松身心的事~
写于 22 年 4 月
前端随笔0:URL与状态的双向绑定的更多相关文章
- Vue2.0源码阅读笔记--双向绑定实现原理
上一篇 文章 了解了Vue.js的生命周期.这篇分析Observe Data过程,了解Vue.js的双向数据绑定实现原理. 一.实现双向绑定的做法 前端MVVM最令人激动的就是双向绑定机制了,实现双向 ...
- 如何在Vue2中实现组件props双向绑定
Vue学习笔记-3 前言 Vue 2.x相比较Vue 1.x而言,升级变化除了实现了Virtual-Dom以外,给使用者最大不适就是移除的组件的props的双向绑定功能. 以往在Vue1.x中利用pr ...
- 前端笔记之微信小程序(二){{}}插值和MVVM模式&数据双向绑定&指令&API
一.双花括号{{}}插值和MVVM模式 1.1 体会{{}}插值 index.wxml的标签不是html的那些标签,这里的view就是div. {{}}这样的插值写法,叫做mustache语法.mus ...
- zabbix添加对web页面url的状态监控
zabbix3.0.4添加对web页面url的状态监控 1.应用集配置 在配置—>主机中打开主机列表,选择需要添加监控主机的web,创建应用集 2.web监测配置 选择web场景,再单击右上角的 ...
- 前端 | 自定义组件 v-model:Vue 如何实现双向绑定
v-model 是 Vue 中一个常用的指令,常用于表单中的数据绑定.如下基本用法想必大家都很熟悉,data 中的 checked 属性的值就会随着多选框的状态实时变化. <el-checkbo ...
- 前端vue之属性指令、style和class、条件渲染、列表渲染、事件处理、数据双向绑定、表单控制、v-model进阶
今日内容概要 属性指令 style和class 条件渲染 列表渲染 事件处理 数据的双向绑定 v-model进阶 购物车案例 内容详细 1.属性指令 <!DOCTYPE html> < ...
- vue2.0 双向绑定原理分析及简单实现
Vue用了有一段时间了,每当有人问到Vue双向绑定是怎么回事的时候,总是不能给大家解释的很清楚,正好最近有时间把它梳理一下,让自己理解的更清楚,下次有人问我的时候,可以侃侃而谈. 一.首先介绍Obje ...
- <meta http-equiv="refresh" content="0; url=">是什么意思?
页面定期刷新,如果加url的,则会重新定向到指定的网页,content后面跟的是时间(单位秒),把这句话加到指定网页的<head></head>里一般也用在实时性很强的应用中, ...
- ORACLE SQL前端补0的三种方式。
前端补0的三种方式. select lpad(sal,8,'0') from emp;select to_char(sal,'00000000') from emp;select substr('00 ...
- HTML <meta> 标签 遇到<meta http-equiv="refresh" content="0; url=">详解
页面定期刷新,如果加url的,则会重新定向到指定的网页,content后面跟的是时间(单位秒),把这句话加到指定网页的<head></head>里一般也用在实时性很强的应用中, ...
随机推荐
- ArcObjects SDK 012 PageLayout和Page
1.从ArcMap角度看结构 一个Mxd文件包含一个PageLayout对象和一个多多个Map对象,每个Map会被包成MapFrame,添加到PageLayout中.我们用ArcMap打开一个mxd文 ...
- day36-ThreadLocal
ThreadLocal 线程数据共享和安全 1.什么是ThreadLocal? ThreadLocal的作用,可以实现在同一个线程数据共享,从而解决多线程数据安全问题 当http请求发送到Tomcat ...
- 快速入门JavaScript编程语言
目录 JS简介 JS基础 1.注释语法 2.引入js的多种方式 3.结束符号 变量与常量 let和var的区别 申明常量 const 严格模式 use strict 基本数据类型 1.数值类型(Num ...
- 02.JavaScript学习笔记1
1.强制类型转换 当使用加号进行运算时,会将数字强制转换为字符串,然后再进行运算. const year = '1991'; console.log(year + 18); console.log(t ...
- flask博客项目之tinymce图片上传
查看当前的博客发表情况 截图一张立马粘贴进来 点击发表,显示数据太长 不断撤退回到刚刚页面 删除大图,换成小图,上传方式 点击发表可以成功发表 数据库中查看,是把图片生成这种编码后字符串方式存储的了, ...
- Centos7下vim最新版本安装
一直以来用的都是vim,因为之前都是系统自带的vim没有研究过怎么自己安装,今天趁着刚装完新系统,顺便装下vim. 同样vim也有两种安装方法: 一.yum安装,centos下安装软件最简单的方法了, ...
- Mybatis用List接收返回值
Mybatis 用 List 接收返回值 以 List<Map<String, Object>> 为例 1.XML内 resultType 为单条记录对应类型,设置成 java ...
- python之路50 ORM执行SQL语句 操作多表查询 双下线方法
ORM执行查询SQL语句 有时候ORM的操作效率可能偏低 我们是可以自己编写SQL的 方式1: models.User.objects.raw('select * from app01_user;') ...
- LVGL 中图片使用问题
此笔记主要是记录在 LVGL 中使用图片的几种方式,以及使用过程中遇到的问题.最近在 ARM linux 中使用 LVGL 时,发现加载图片变得很卡,一开始还好,当连续加载的图片变多后,特别是动画的过 ...
- 真正“搞”懂HTTP协议08之重定向
我们知道,用来传输页面的协议就是HTTP协议,全称是超文本传输协议,而浏览器展示的页面则是用HTML编写的,HTML的全称则是超文本标记语言.你看,都叫做超文本,我在第一篇文章的时候也详细的聊过,超文 ...