当前位置: 首页 > news >正文

广州番禺搜索引擎优化的各种方法

广州番禺,搜索引擎优化的各种方法,什么软件做网站好,上海市城乡建设管理局网站问题复现 最近我突然接手一个后台的bug,这个后台很久没有迭代更新了,我也不熟悉业务,所以只能看一下源码,问题很快就复现,测试的修复操作也很正确,就是因为渲染的input标签中存在disableddisabled’属性导…

问题复现

最近我突然接手一个后台的bug,这个后台很久没有迭代更新了,我也不熟悉业务,所以只能看一下源码,问题很快就复现,测试的修复操作也很正确,就是因为渲染的input标签中存在disabled='disabled’属性导致的。

不过很奇怪的是,我问之前是正常的吗?

这部分代码已经很久没有改动过了

但是测试和运营那边的人员都坚持,两个月前还是正常的,记录能够证明,我先怀疑的是,两个月前是正常的,那是不是两个月前有迭代,谁更新了什么依赖的版本导致出现的bug,然后就开始找仓库最后一次修改记录。

查找记录

确实这个仓库的最后一次提交记录是一个月前,然后我就仔细看了一下,是修改了什么导致的

但是最后一次修改记录中,也没有改到依赖package.json,也没有更新lock文件,只有三个文件的变化,这看着都不会影响全局的内容,最重要的是,没有改到相关页面的代码。

代码本地回滚

没有其他办法,我只能本地代码回滚,看看是不是上次迭代导致出现了bug,但是代码回滚之后,这个问题依然存在。

我开始思考,项目是vue2的,vue的版本是2.7.14

导致的原因是disabled属性

这是一个子组合,父组件传递的属性确实是false,而且不传递这个属性时,默认值也是false

问题修复

我写了一个在线的demo复现

https://codesandbox.io/s/intelligent-engelbart-3h9fcq

代码如下:

<template><div id="app"><HelloWorld msg="Hello Vue in CodeSandbox!" /><div class="box"><input disabled /></div><hr /><div class="box"><input :disabled="disabledVal" /></div></div>
</template><script>
import HelloWorld from "./components/HelloWorld";export default {name: "App",components: {HelloWorld,},data() {return {disabled: false,disabledVal: false,};},
};
</script><style>
#app {font-family: "Avenir", Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50;margin-top: 60px;
}
.box {width: 100%;height: 100px;display: flex;justify-content: center;align-items: center;
}
</style>

页面解析如下:

由于data中或者props中,disabled变量,直接赋值给template模板中的disabled的属性;当disabled变量为false,页面解析出来的标签还是带有disabled属性的,属性值也是disabled,浏览器的表现形式为禁用,这其实不符合逻辑了。


当disabled变量为true,就直接禁用

当disabled变量为false,是不禁用状态

这才是理想状态,看来这是vue2解析的问题,把变量名改成disabledVal,这个问题就解决了,这说明Vue2对元素自带属性,不能定义为变量,不然很容易出现问题呀。

到这里大家请牢记,取变量名很重要,能够阻止一些奇怪的bug产生哦

根本原因

到这里我还是疑惑的,为什么之前能够正常使用的,现在突然不能用了?盯着bug工单上的浏览器版本,我赶紧查看了谷歌浏览器更新的新特性

还真被我找到了,全局搜索disabled还是很有用的

原文在这里

https://chromestatus.com/feature/6128674512830464

翻译截图

正好是116版本的新特性,而存在disabled属性的元素禁止点击事件了,这也是为什么两个月前是正常的原因了

正好是一个月前发布的,而我的电脑设置的是自动检测更新,所以已经更新到最新版本了,而谷歌浏览器默认是自动更新,所以就出现了这个bug.

对比

114版本

很多小伙伴不知道如果是116版本以前的浏览器会是什么效果,正好我有两个浏览器,一个已经自动升级到最新版本,一个还是114版本

image.png

现在我们就对比一下,两者又有何不同

代码如下:

<template>
<div id="app">
<HelloWorld msg="Hello Vue in CodeSandbox!" />
<div class="box">
<input @click="handleClick" disabled />
</div>
<hr />
<div class="box">
<input @click="handleClick" :disabled="disabledVal" />
</div>
</div>
</template><script>
import HelloWorld from "./components/HelloWorld";
export default {name: "App",components: {HelloWorld,},data() {return {disabled: false,disabledVal: false,};},methods: {handleClick() {console.log('click----')}}
};
</script><style>
#app {
font-family: "Avenir", Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
.box {
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items: center;
background-color: pink;
}
</style>

效果如下:

222.gif

同样的代码,在114版本的时候,我们发现disabled为false的时候,这个input标签是禁用状态,
而且我们可以给这个input标签父元素绑定点击事件,这个点击事件是能够执行的.

另外codesandbox可以打开到新tab页观看效果

image.png

这样打开就能打开控制台,看到vue编译之后的HTML模板了

image.png

116版本

现在我们接着来看116版本的, 虽然是Microsoft Edge浏览器,但依旧是谷歌内核哦, 所以还是一样的

image.png

效果如下:

222.gif

我们能够看到, 这里的116版本的是已经禁止了点击事件冒泡的, 114版本的是还能够点击事件冒泡传播.

所以导致这个bug出现, 正是谷歌内核新增新特性导致的, 禁止了点击事件.

http://www.wangmingla.cn/news/110177.html

相关文章:

  • 怎么做体育直播网站网站目录
  • 门户网站制作流程小学生抄写新闻20字
  • 展示型网站建设标准武汉seo关键词排名优化
  • 网站建设彩铃定制化网站建设
  • 动态asp.net网站开发推广
  • 文化网站设计经典案例山西疫情最新情况
  • 网站域名更换相应内容视频号推广方法
  • 小型企业网站模板谷歌海外推广
  • css 建设网站 图文教程百度大全下载
  • 自己做的网站如何兼容百度登录账号首页
  • 集约化网站建设项目河北seo基础入门教程
  • 怎么添加网站背景音乐网店推广的作用
  • 军事网址大全网站seo推广营销
  • 做服装批发在哪个网站好免费开发软件制作平台
  • 商城网站 免费开源怎么做谷歌推广
  • 冠县网站建设微信社群营销怎么做
  • 肇庆住房和城乡建设部网站网页关键词排名优化
  • wordpress标签自动西安网站seo费用
  • Wordpress建站的万能搜索引擎
  • 广州h5网站建设公司ks数据分析神器
  • 台州椒江找人做网站免费的个人主页网页制作网站
  • 做动态网站用什么软件免费二级域名分发平台
  • 个人网站建站的流程软文广告经典案例300字
  • 怀化网站建设如何把网站推广出去
  • 网网站设计培训课程设计
  • 南通网站公司网站推广营销企业
  • 佛山网站建设哪家专业网络赚钱推广
  • 台州网络建站模板西安疫情最新消息
  • 顺义网站做的比较好的公司上海网站建设联系方式
  • 宁波 seo整体优化网站seo诊断分析报告