如何捕获input hidden的 value变更

最近开始工作了。手里事情比较多。 遇到这个挺有代表性的问题。

背景

  • onChange 事件触发的机制,当input表单控件发生变化时,并且 input 触发失焦,则会触发 Change 事件。

像Onchage 标准文档描述,显然 不符合这个标准。 本文主要讨论, input type = hidden 元素,当value 发生变更时,如何捕获值的变更。

解决方案

IE9 及以下 IE 类浏览器

虽然onChange 事件无法触发, 但是旧的 IE 浏览器,是有自己的私有事件 onpropertychange 。 这个事件是在表单控件所以属性发生变化时候触发。 当然可以做为value 变更的替代来使用。可惜限制条件特别多。

其他浏览器

根据过往经验, 我们在通过js 修改 input hidden 的值的时候,同步触发一下事件,是比较合理的解决方案。 示例代码如下:

ini 复制代码
// DOM 
// <input type="hidden" id="hidden-input" onchange="console.log('hello world')">
	
// script 
document.getElementById("hidden-input").value = "new value";
document.getElementById("hidden-input").onchange();

通过 MutationObserver 解决

像传统的解决方案,每次赋值手动触发一下。 显得很不优雅。

在IE 11以上 及 chrome 等现代浏览器,我们可以比较优雅的解决这个问题。

示例解决代码:

javascript 复制代码
var obsever = new MutationObserver(function(mutations, obsever) {
			    mutations.forEach((mutation) => {
					switch (mutation.type) {
						case "attributes":
							switch (mutation.attributeName) {
								case "value":
									obsever.dispatch(new UIEvent('change'))
								break;
							}
						break;
					}
				});
			});
obsever.observe(document.getElementsById('hidden-input'), {
	attributeFilter: ["value"],
})
相关推荐
天渺工作室14 分钟前
别再写改名脚本了,一个 Vite 插件搞定压缩、校验、自动哈希命名vite-plugin-pack-orchestrator
前端·vite
薯老板21 分钟前
事件循环(Event Loop)
javascript
大龄程序员狗哥22 分钟前
第30篇:使用Flask部署你的第一个AI模型——打造简易Web API(项目实战)
前端·人工智能·flask
AI砖家1 小时前
解剖 Claude Code:如何搭建一个企业级的私有化 AI 编程助手
前端·人工智能·ai编程
用户5757303346241 小时前
拒绝“首屏爆炸”:用 React 哨兵模式与懒加载打造丝滑列表
前端
大腕先生2 小时前
通用分页超详细介绍(附带源代码解析&页面展示效果)
xml·java·linux·服务器·开发语言·前端·idea
睿智的海鸥2 小时前
Markdown 语法大全详解
开发语言·前端·javascript·css·html
Highcharts.js2 小时前
用Highcharts如何动态向一个序列添加点
前端·javascript·react.js·highcharts
HookJames2 小时前
设计Section 09 · Cost & Lead Time Factors 的完整 Block Editor 操作步骤
前端
玖玖passion3 小时前
React 常用 Hooks 函数及使用方法完全指南(useState / useEffect / useRef / useContext / useCallback / useMemo / useReducer)
前端·javascript