结合Vue控制字符和字节的显示个数的示例
发布时间:2020-12-17 02:16:58 所属栏目:百科 来源:网络整理
导读:需求 需求:结合Vue实现下面的效果 输入框中最多输入16个字符 汉字最多显示5个,超出部分以 ... 显示 英文最多显示10个,超出部分以 ... 显示 实现 搭建简单页面,并设置简单样式 在正式开始写核心代码之前,要先把代码结构搭建起来,这样后面写的时候就会看
需求需求:结合Vue实现下面的效果
实现搭建简单页面,并设置简单样式在正式开始写核心代码之前,要先把代码结构搭建起来,这样后面写的时候就会看着简洁点了。 首先需要一个输入框用来输入内容,其次需要一个元素,用来显示输入框中的内容,实现数据的双向绑定。 其中,输入内容的最大长度是可以通过input标签的属性来指定的。 内容:{{txt}}
输入的字符个数:{{computedCharLen}} 输入的字节个数:{{computedByteLen}} 页面的结构已经搭建完成了,那下面就是做一些简单的样式优化了。 最后一步应该就是引入Vue,然后搭建一些简单的数据内容。 ASCII范围内与范围外了解ASCII的内容,请移步到 ASCII中包含256个字符,因此超过256之外的字符,全部都是非ASCII字符,一般情况下,汉字就是在这个范围中。 因此,编码不在0-255的字符可以使用正则表达式 我们修改一下页面结构,输出一些测试信息: 内容:{{txt}}
输入的字符个数:{{computedCharLen}} 输入的字节个数:{{computedByteLen}} 补充需要的计算属性: 这个时候,我们输入内容,出现下面的效果: 这个时候会发现,已经实现,ASCII码范围内的占1位,超出范围的占2位。 控制显示的内容内容显示使用计算属性来实现: 内容:{{computedTxt}}
下面补充一下 = len) {
// Math.floor(i / 2) * 这里是控制特殊情况的显示
// 如 '一二aaa一二三四',显示的结果就是 '一二aaa一...'
return str.substr(0,Math.floor(i / 2) * 2) + '...'
}
}
}
最终的显示情况没有超过最大指定长度的情况 超过最大指定长度(汉字输入) 超过最大指定长度(数字输入) 超过最大指定长度(汉字和字母的组合) 完整代码最后,把最终代码粘贴出来:
Document
内容:{{computedTxt}}
输入的字符个数:{{computedCharLen}} 输入的字节个数:{{computedByteLen}} |