From 0c791a1efc539d06742ae14375d4d5ddfd1339f5 Mon Sep 17 00:00:00 2001 From: 疯狂的狮子Li <15040126243@163.com> Date: 星期二, 25 七月 2023 15:59:35 +0800 Subject: [PATCH] update 优化 封装全局统一请求头 --- src/components/Editor/index.vue | 130 +++++++++++++++++++++--------------------- 1 files changed, 65 insertions(+), 65 deletions(-) diff --git a/src/components/Editor/index.vue b/src/components/Editor/index.vue index bc8da7b..9c61f3b 100644 --- a/src/components/Editor/index.vue +++ b/src/components/Editor/index.vue @@ -1,73 +1,58 @@ <template> <div> <el-upload - :action="uploadUrl" - :before-upload="handleBeforeUpload" - :on-success="handleUploadSuccess" - :on-error="handleUploadError" - class="editor-img-uploader" - name="file" - :show-file-list="false" - :headers="headers" - style="display: none" - ref="uploadRef" - v-if="type == 'url'" + :action="upload.url" + :before-upload="handleBeforeUpload" + :on-success="handleUploadSuccess" + :on-error="handleUploadError" + class="editor-img-uploader" + name="file" + :show-file-list="false" + :headers="upload.headers" + style="display: none" + v-if="type === 'url'" > </el-upload> <div class="editor"> <quill-editor - ref="myQuillEditor" - v-model:content="content" - contentType="html" - @textChange="(e) => $emit('update:modelValue', content)" - :options="options" - :style="styles" + ref="myQuillEditor" + v-model:content="content" + contentType="html" + @textChange="(e: any) => $emit('update:modelValue', content)" + :options="options" + :style="styles" /> </div> </div> </template> -<script setup> +<script setup lang="ts"> import { QuillEditor, Quill } from '@vueup/vue-quill'; import '@vueup/vue-quill/dist/vue-quill.snow.css'; -import { getToken } from "@/utils/auth"; +import { propTypes } from '@/utils/propTypes'; +import { globalHeaders } from "@/utils/request"; const props = defineProps({ /* 缂栬緫鍣ㄧ殑鍐呭 */ - modelValue: { - type: String, - }, + modelValue: propTypes.string, /* 楂樺害 */ - height: { - type: Number, - default: null, - }, + height: propTypes.number.def(400), /* 鏈�灏忛珮搴� */ - minHeight: { - type: Number, - default: null, - }, + minHeight: propTypes.number.def(400), /* 鍙 */ - readOnly: { - type: Boolean, - default: false, - }, + readOnly: propTypes.bool.def(false), /* 涓婁紶鏂囦欢澶у皬闄愬埗(MB) */ - fileSize: { - type: Number, - default: 5, - }, + fileSize: propTypes.number.def(5), /* 绫诲瀷锛坆ase64鏍煎紡銆乽rl鏍煎紡锛� */ - type: { - type: String, - default: "url", - } + type: propTypes.string.def('url') }); -const { proxy } = getCurrentInstance(); -// 涓婁紶鐨勫浘鐗囨湇鍔″櫒鍦板潃 -const uploadUrl = ref(import.meta.env.VITE_APP_BASE_API + "/system/oss/upload"); -const headers = ref({ Authorization: "Bearer " + getToken() }); +const { proxy } = getCurrentInstance() as ComponentInternalInstance; + +const upload = reactive<UploadOption>({ + headers: globalHeaders, + url: import.meta.env.VITE_APP_BASE_API + '/resource/oss/upload' +}) const myQuillEditor = ref(); const options = ref({ @@ -80,7 +65,7 @@ container: [ ["bold", "italic", "underline", "strike"], // 鍔犵矖 鏂滀綋 涓嬪垝绾� 鍒犻櫎绾� ["blockquote", "code-block"], // 寮曠敤 浠g爜鍧� - [{ list: "ordered" }, { list: "bullet"} ], // 鏈夊簭銆佹棤搴忓垪琛� + [{ list: "ordered" }, { list: "bullet" }], // 鏈夊簭銆佹棤搴忓垪琛� [{ indent: "-1" }, { indent: "+1" }], // 缂╄繘 [{ size: ["small", false, "large", "huge"] }], // 瀛椾綋澶у皬 [{ header: [1, 2, 3, 4, 5, 6, false] }], // 鏍囬 @@ -90,10 +75,10 @@ ["link", "image", "video"] // 閾炬帴銆佸浘鐗囥�佽棰� ], handlers: { - image: function (value) { + image: function (value: any) { if (value) { // 璋冪敤element鍥剧墖涓婁紶 - document.querySelector(".editor-img-uploader>.el-upload").click(); + (document.querySelector(".editor-img-uploader>.el-upload") as HTMLDivElement)?.click(); } else { Quill.format("image", true); } @@ -106,7 +91,7 @@ }); const styles = computed(() => { - let style = {}; + let style: any = {}; if (props.minHeight) { style.minHeight = `${props.minHeight}px`; } @@ -118,66 +103,70 @@ const content = ref(""); watch(() => props.modelValue, (v) => { - if (v !== content) { + if (v !== content.value) { content.value = v === undefined ? "<p></p>" : v; } }, { immediate: true }); // 鍥剧墖涓婁紶鎴愬姛杩斿洖鍥剧墖鍦板潃 -function handleUploadSuccess(res, file) { +const handleUploadSuccess = (res: any) => { // 鑾峰彇瀵屾枃鏈疄渚� let quill = toRaw(myQuillEditor.value).getQuill(); // 濡傛灉涓婁紶鎴愬姛 - if (res.code == 200) { + if (res.code === 200) { // 鑾峰彇鍏夋爣浣嶇疆 let length = quill.selection.savedRange.index; // 鎻掑叆鍥剧墖锛宺es涓烘湇鍔″櫒杩斿洖鐨勫浘鐗囬摼鎺ュ湴鍧� quill.insertEmbed(length, "image", res.data.url); // 璋冩暣鍏夋爣鍒版渶鍚� quill.setSelection(length + 1); - proxy.$modal.closeLoading(); + proxy?.$modal.closeLoading(); } else { - proxy.$modal.loading(res.msg); - proxy.$modal.closeLoading(); + proxy?.$modal.loading(res.msg); + proxy?.$modal.closeLoading(); } } // 鍥剧墖涓婁紶鍓嶆嫤鎴� -function handleBeforeUpload(file) { +const handleBeforeUpload = (file: any) => { // 鏍℃鏂囦欢澶у皬 if (props.fileSize) { const isLt = file.size / 1024 / 1024 < props.fileSize; if (!isLt) { - proxy.$modal.msgError(`涓婁紶鏂囦欢澶у皬涓嶈兘瓒呰繃 ${props.fileSize} MB!`); + proxy?.$modal.msgError(`涓婁紶鏂囦欢澶у皬涓嶈兘瓒呰繃 ${props.fileSize} MB!`); return false; } } - proxy.$modal.loading("姝e湪涓婁紶鏂囦欢锛岃绋嶅��..."); + proxy?.$modal.loading('姝e湪涓婁紶鏂囦欢锛岃绋嶅��...'); return true; } // 鍥剧墖澶辫触鎷︽埅 -function handleUploadError(err) { - proxy.$modal.msgError("涓婁紶鏂囦欢澶辫触"); +const handleUploadError = (err: any) => { + console.error(err); + proxy?.$modal.msgError('涓婁紶鏂囦欢澶辫触'); } - </script> <style> -.editor, .ql-toolbar { +.editor, +.ql-toolbar { white-space: pre-wrap !important; line-height: normal !important; } + .quill-img { display: none; } + .ql-snow .ql-tooltip[data-mode="link"]::before { content: "璇疯緭鍏ラ摼鎺ュ湴鍧�:"; } + .ql-snow .ql-tooltip.ql-editing a.ql-action::after { - border-right: 0px; + border-right: 0; content: "淇濆瓨"; - padding-right: 0px; + padding-right: 0; } .ql-snow .ql-tooltip[data-mode="video"]::before { @@ -188,14 +177,17 @@ .ql-snow .ql-picker.ql-size .ql-picker-item::before { content: "14px"; } + .ql-snow .ql-picker.ql-size .ql-picker-label[data-value="small"]::before, .ql-snow .ql-picker.ql-size .ql-picker-item[data-value="small"]::before { content: "10px"; } + .ql-snow .ql-picker.ql-size .ql-picker-label[data-value="large"]::before, .ql-snow .ql-picker.ql-size .ql-picker-item[data-value="large"]::before { content: "18px"; } + .ql-snow .ql-picker.ql-size .ql-picker-label[data-value="huge"]::before, .ql-snow .ql-picker.ql-size .ql-picker-item[data-value="huge"]::before { content: "32px"; @@ -205,26 +197,32 @@ .ql-snow .ql-picker.ql-header .ql-picker-item::before { content: "鏂囨湰"; } + .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before, .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before { content: "鏍囬1"; } + .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before, .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before { content: "鏍囬2"; } + .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before, .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before { content: "鏍囬3"; } + .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before, .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before { content: "鏍囬4"; } + .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before, .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before { content: "鏍囬5"; } + .ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before, .ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before { content: "鏍囬6"; @@ -234,10 +232,12 @@ .ql-snow .ql-picker.ql-font .ql-picker-item::before { content: "鏍囧噯瀛椾綋"; } + .ql-snow .ql-picker.ql-font .ql-picker-label[data-value="serif"]::before, .ql-snow .ql-picker.ql-font .ql-picker-item[data-value="serif"]::before { content: "琛嚎瀛椾綋"; } + .ql-snow .ql-picker.ql-font .ql-picker-label[data-value="monospace"]::before, .ql-snow .ql-picker.ql-font .ql-picker-item[data-value="monospace"]::before { content: "绛夊瀛椾綋"; -- Gitblit v1.9.3