位置: IT常识 - 正文

缺陷修改实践——replace函数的运用|思考?(缺陷修饰)

编辑:rootadmin
缺陷修改实践——replace函数的运用|思考? 目录介绍问题出现问题分析解决方法优化实现总结介绍

推荐整理分享缺陷修改实践——replace函数的运用|思考?(缺陷修饰),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:缺陷和变更管理系统,缺陷修改后一定会对软件带来有益的影响吗,缺陷修饰,缺陷修饰,缺陷管理与改错计划,缺陷改进指的是,改变缺陷,缺陷修改后一定会对软件带来有益的影响吗,内容如对您有帮助,希望把文章链接给更多的朋友!

大家好,我是清风。今天给大家分享一个项目中遇到问题解决问题的案例,编程其实就是一个思考的过程,缺少思考就没有灵魂,遇到问题先静下心去思考,想到方法后再去实践。我们要学会灵活变通去解决问题,掌握方法,这样才能举一反三,临危不乱,遇到所有问题都能很好地去解决。

事情是这样的,做的一个答题小程序,要求在后台编辑题目,编辑题目是用的textarea文本域,即输入的是文本内容,配置之后小程序里查询显示后台配置的题目列表。

当然在测试时后台去配置文本内容,小程序显示是没有问题的。因为配置的题目是纯文本,小程序里也是直接在text里显示的,没有问题。

后台配置题目

小程序显示题目

问题出现

问题往往只有在用的时候才会发现,用户或管理员的各种操作才能显现出各种问题。现在小程序里已经不能正常显示了,有些显示的是html格式富文本格式,有些不显示。显然和需求大相径庭,已经出现问题了。

问题分析

如上图,在用的时候因为是从word文档里直接复制过去的题目(事先在word里整理好了题目,由于各部门工作对接,先是在word文档进行审核),直接复制会把富文本内容也携带过去,携带过去的当然也有style样式,小程序里不显示的原因是富文本的字体颜色是黑色字体,和小程序面背景都是黑色,导致看不到文字。打开控制台调试,问题确实是这么出现的。

缺陷修改实践——replace函数的运用|思考?(缺陷修饰)

word文档编辑的题目会出现不同的富文本的样式格式,这都会导致小程序的不正常显示。

富文本的文字颜色是黑色,这导致的小程序页里题目的不显示。

解决方法

既然后台有可能出现富文本,我们直接把小程序题目的渲染方式换成富文本渲染,这样就算是纯文本也可以显示的。而第二个问题,由于小程序页面背景颜色是黑色,所以题目的字体颜色不能是黑色,我们做一个查找替换,把style样式里的字体样式替换掉就可以了。

优化

样式可能是各种各样的,通过查找style样式里的字体样式考虑的匹配太多了,比如说color属性值可以是rgb形式,也可是rgba形式,也可能是#号颜色值形式,还有可能是英文形式颜色,所以不可取。我们换一种思路,直接把style属性替换掉,即查找到style,换成一个无效的属性名。案例中我们替换成了c,c是一个无效的属性,不会触发节点的查找和计算。

replace函数

我们用到replace函数,replace()方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

参数

regexp/substr,必需。规定子字符串或要替换的模式的 RegExp 对象。replacement,必需。一个字符串值。规定了替换文本或生成替换文本的函数。

请注意,regexp/substr 是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为 RegExp对象,返回值是一个新的字符串,是用 replacement 替换了 regexp 的第一次匹配或所有匹配之后得到的。

实现

replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

that.setData({ _list: res.data }) let data = that.data._list data.forEach((element, index) => { var stemContent = '_list[' + index + '].stemContent' that.setData({ [stemContent]: element.stemContent.replace(/style/g, 'c') }) element.choiceTopicVos.forEach((item, i) => { var listCheck = '_list[' + index + '].choiceTopicVos[' + i + '].optionDes'; that.setData({ [listCheck]: item.optionDes.replace(/style/g, 'c') }) }) })

用到的replace函数,进行了字符串的查找替换,查找到style属性,把它替换到了无效的属性c,没有了样式属性,从而达到了去除内联样式的效果,经过调试,完美解决问题。

总结

这是一个小问题,我为什么要拿出来说呢?抛去开发的测试流程不说,我认为它能引发一些思考。写代码的过程必须是一个思考的过程,怎么样更好地去实现效果,怎么样更简单有效地解决问题,怎么样优化,要去考虑一个大的方面。善于发现问题,解决问题,并不是说用了什么高级语言就鄙弃了思考,机器语言是相通的,开发中各种各样地应用才是魅力所在。编程是一门是艺术,最重要的是你怎样去巧妙地运用,就像解一道数学题,精绝巧妙的解法会让人眼前一亮,增色太多。同样都做出来了,但是你做的就显得十分优雅!

方法都是思考出来的,能高效解决问题的方法就是好方法,大家如果还有更好的解决方法欢迎评论区留言

本文链接地址:https://www.jiuchutong.com/zhishi/300722.html 转载请保留说明!

上一篇:手把手带你调参Yolo v5(一)(调参数是什么意思)

下一篇:Nginx跨域解决方案(nginx跨域配置详解)

  • 税务局做社保关联带什么资料
  • 往来款项包括什么
  • 弱电系统多少钱
  • 出差人员报销差额怎么算
  • 加油站的成品油许可证变更过后有什么风险
  • 财产租赁所得如何申报
  • 账本印花税怎么做账
  • 律师事务所日常管理松懈混乱整改措施
  • 专票开票出框可以改吗
  • 消费税的纳税环节可能有
  • 认证后的发票可以留存多久
  • 一般纳税人预缴税款几个点
  • 写着个人的发票能下账吗
  • 只有进项没有销项怎么报税
  • 1697507882
  • 应交税费待抵扣进项税额是什么科目
  • 桌面图标变成了白色的
  • 本月的应收账款,实际到下个月了会怎么样
  • 存货损失进项税
  • win11升级卡66
  • 实例简介php的一般过程
  • 营改增餐饮行业纳税规则
  • window10没有激活码
  • 如何更改自己
  • 项目设计费怎么计算
  • 债务重组是什么工作
  • linux双ip路由设置方法
  • 小程序在线反编译网页版
  • word下划线怎么延长
  • php验证码显示不出来
  • 施工企业会计核算特点有哪些
  • phpnow升级php版本
  • php如何防止后门
  • nodejs安装与配置
  • 车间装修预算表
  • ChatGPT会让6个低端岗位失业
  • 出口退税进项税额转出怎么申报
  • c标准库pdf下载
  • PostgreSQL教程(一):数据表详解
  • 结转成本注意事项
  • 小规模纳税人增值税申报表怎么填
  • 待抵扣进项税额和待认证进项税额的区别
  • 总公司和分公司不在一个区怎么纳税
  • 应付职工薪酬代扣社保
  • 发给客户免费的短信
  • 长期待摊费用未摊销完一次性处理怎么走
  • 个人购买机动车需要交增值税吗
  • 固定资产折旧计算表模板
  • 忘交残保金了怎么补交
  • win7 mysql5.7.21安装
  • mysql数据库用户名和密码怎么查看
  • win8系统运行慢怎么办
  • win8开始菜单怎么设置
  • u盘安装winpe
  • u盘pe系统安装步骤
  • win8如何删除登录密码
  • win10技巧 新功能
  • centos升级命令
  • 如何设置windows密码
  • nmeo.exe是什么
  • win10 预览版 移除 tab 栏 特性
  • linux服务端
  • windows7开机
  • linux wc-w
  • opengles版本过低怎么办
  • windows升级node版本
  • unity mrt
  • linux 网卡 配置
  • vue导航组件
  • node.js怎么用
  • linux安全加固的内容是什么
  • js实现兼容性较好的方法
  • python win10
  • 资产管理公司收购不良资产后怎么处置
  • 江西企业社保缴费基数查询
  • 完税证明可以自己在家打印吗
  • popl期刊
  • 实名办税的法律依据
  • 法制观念的问题
  • 内蒙古个人所得税app下载
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设