From f63803529af536ec14ee1cd6cd80557442b3a1fa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=9D=92=E8=8F=9C=E7=99=BD=E7=8E=89=E6=B1=A4?= <79054161+Azir-11@users.noreply.github.com> Date: Sun, 10 Nov 2024 17:02:31 +0800 Subject: [PATCH] =?UTF-8?q?perf(projects):=20=E5=A2=9E=E5=BC=BA=E6=96=87?= =?UTF-8?q?=E4=BB=B6=E6=A0=A1=E9=AA=8C=E7=9A=84=E5=85=BC=E5=AE=B9=E6=80=A7?= =?UTF-8?q?=20(#1931)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- web/src/components/office/index.vue | 2 +- .../components/selectImage/selectImage.vue | 2 +- web/src/components/upload/image.vue | 4 +-- web/src/utils/image.js | 28 +++++++++++-------- web/src/view/example/upload/upload.vue | 2 +- 5 files changed, 21 insertions(+), 17 deletions(-) diff --git a/web/src/components/office/index.vue b/web/src/components/office/index.vue index fa503be855..d22d6da4d9 100644 --- a/web/src/components/office/index.vue +++ b/web/src/components/office/index.vue @@ -39,7 +39,7 @@ fileUrl.value = val const fileExt = val.split('.')[1] || '' const image = ['png', 'jpg', 'jpeg', 'gif'] - ext.value = image.includes(fileExt) ? 'image' : fileExt + ext.value = image.includes(fileExt?.toLowerCase()) ? 'image' : fileExt }, { immediate: true } ) diff --git a/web/src/components/selectImage/selectImage.vue b/web/src/components/selectImage/selectImage.vue index 3be279db0d..2c08d88e5e 100644 --- a/web/src/components/selectImage/selectImage.vue +++ b/web/src/components/selectImage/selectImage.vue @@ -218,7 +218,7 @@ const chooseImg = (url) => { if (props.fileType) { const typeSuccess = listObj[props.fileType].some((item) => { - if (url.includes(item)) { + if (url?.toLowerCase().includes(item)) { return true } }) diff --git a/web/src/components/upload/image.vue b/web/src/components/upload/image.vue index d7f021ca94..7423cc7def 100644 --- a/web/src/components/upload/image.vue +++ b/web/src/components/upload/image.vue @@ -38,8 +38,8 @@ }) const beforeImageUpload = (file) => { - const isJPG = file.type === 'image/jpeg' - const isPng = file.type === 'image/png' + const isJPG = file.type?.toLowerCase() === 'image/jpeg' + const isPng = file.type?.toLowerCase() === 'image/png' if (!isJPG && !isPng) { ElMessage.error('上传头像图片只能是 jpg或png 格式!') return false diff --git a/web/src/utils/image.js b/web/src/utils/image.js index a2d3241e85..8b65232953 100644 --- a/web/src/utils/image.js +++ b/web/src/utils/image.js @@ -106,17 +106,21 @@ export const getUrl = (url) => { } } -export const isVideoExt = (url) => - url.endsWith('.mp4') || - url.endsWith('.mov') || - url.endsWith('.webm') || - url.endsWith('.ogg') +const VIDEO_EXTENSIONS = ['.mp4', '.mov', '.webm', '.ogg'] +const VIDEO_MIME_TYPES = ['video/mp4', 'video/webm', 'video/ogg'] +const IMAGE_MIME_TYPES = ['image/jpeg', 'image/png', 'image/webp', 'image/svg+xml'] -export const isVideoMime = (type) => - type == 'video/mp4' || type == 'video/webm' || type == 'video/ogg' +export const isVideoExt = (url) => { + const urlLower = url?.toLowerCase() || '' + return urlLower !== '' && VIDEO_EXTENSIONS.some(ext => urlLower.endsWith(ext)) +} + +export const isVideoMime = (type) => { + const typeLower = type?.toLowerCase() || '' + return typeLower !== '' && VIDEO_MIME_TYPES.includes(typeLower) +} -export const isImageMime = (type) => - type == 'image/jpeg' || - type == 'image/png' || - type == 'image/webp' || - type == 'image/svg+xml' +export const isImageMime = (type) => { + const typeLower = type?.toLowerCase() || '' + return typeLower !== '' && IMAGE_MIME_TYPES.includes(typeLower) +} diff --git a/web/src/view/example/upload/upload.vue b/web/src/view/example/upload/upload.vue index 8e85613f8c..42a4c9161d 100644 --- a/web/src/view/example/upload/upload.vue +++ b/web/src/view/example/upload/upload.vue @@ -50,7 +50,7 @@