通过查阅官方文档和众多资料发现,在QuillEditor的使用中,行高的配置并不像加粗、斜体等样式仅需配置关键词即可,那么QuillEditor的行高如何配置呢?
首先我们仍然要在富文本的配置的modules中写入行高的配置项
const myOptions = reactive({modules: {toolbar: {container: [['bold', 'italic', 'underline', 'strike'], // 加粗、斜体、下划线、删除线[{ header: [1, 2, 3, 4, 5, 6, false] }], // 标题,不同级别的标题[{ align: [] }], // 对齐方式['blockquote', 'code-block'], // 引用,代码块[{ script: 'sub' }, { script: 'super' }], // 上标/下标[{ list: 'ordered' }, { list: 'bullet' }], // 有序、无序列表[{ indent: '-1' }, { indent: '+1' }], // 缩进['link', 'image', 'video'], // 超链接 图片 视频[{ direction: 'rtl' }], // 文本方向[{ color: [] }, { background: [] }], // 字体颜色和背景色[{ size: fontSizeStyle.whitelist }], // 字体大小[{ font: fontStyle.whitelist }], // 字体[{ lineheight: lineHeight }], // 设置行高['clean'], // 清除格式],handlers: {lineheight: (value) => {const editor = quillRef.value.getQuill();if (value) {editor.format('lineHeight', value);}},},},},placeholder: '请输入内容...',
});
同时在modules之外还应设置
// 设置行高的配置======start
const lineHeight = ['1', '1.25', '1.5', '1.75', '2.5', '3', '5'];
const parchment = Quill.import('parchment');
const lineHeightConfig = {scope: parchment.Scope.INLINE,whitelist: lineHeight,
};
const lineHeightStyle = new parchment.Attributor.Style('lineHeight','line-height',lineHeightConfig,
);
Quill.register({ 'formats/lineHeight': lineHeightStyle }, true);
// 设置行高的配置======end
行高的样式文件需在style中进行定义,在modules中引入的数值需在css文件中已经定义。
.ql-snow .ql-picker.ql-lineheight .ql-picker-label::before {content: '行高';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='1']::before {content: '1';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='1.5']::before {content: '1.5';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='1.75']::before {content: '1.75';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='2']::before {content: '2';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='3']::before {content: '3';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='4']::before {content: '4';
}
.ql-snow .ql-picker.ql-lineheight .ql-picker-item[data-value='5']::before {content: '5';
}
.ql-snow .ql-picker.ql-lineheight {width: 70px;
}