开发 H5 遇到过几回竖排文字的需求,把实现思路梳理一下。javascript
<input>
标签没有竖排的属性,最早尝试修改 <input>
的样式来实现效果,可是效果不理想。最后使用 HTML 的 contenteditable
属性。css
想经过限定 输入框的宽度 与 文字的大小 ,让文字自动换行。html
input{
width: 30px;
height: 250px;
font-size: 30px;
}
复制代码
contenteditable
属性代替 <input>
(推荐)HTML 的 contenteditable
属性规定元素内容是否可编辑。java
<div contenteditable="true" style="writing-mode: vertical-lr; writing-mode: tb-lr; "></div>
复制代码
contenteditable
属性使 div 可编辑writing-mode
属性让文字垂直排列Canvas 一样没有竖排文字的属性,我经过遍历文字的方式进行绘制。web
let name; // 文本内容
let x = 657,y=170; // 文字开始的坐标
let letterSpacing = 10; // 设置字间距
for(let i = 0; i < this.name.length; i++){
const str = this.name.slice(i,i+1).toString();
if(str.match(/[A-Za-z0-9]/)&&(y<576)){ // 非汉字 旋转
ctx.save();
ctx.translate(x,y);
ctx.rotate(Math.PI/180*90);
ctx.textBaseline = 'bottom';
ctx.fillText(str,0,0);
ctx.restore();
y+=ctx.measureText(str).width+letterSpacing; // 计算文字宽度
}else if(str.match(/[\u4E00-\u9FA5]/)&&(y<576)){
ctx.save();
ctx.textBaseline = 'top';
ctx.fillText(str,x,y);
ctx.restore();
y+=ctx.measureText(str).width+letterSpacing; // 计算文字宽度
}
}
复制代码
measureText()
计算字符宽度,使中英文字间距更和谐