From 97c3930235fb3466b26502914f0579dc5faea65e Mon Sep 17 00:00:00 2001 From: fxy060608 Date: Mon, 26 Jul 2021 15:30:09 +0800 Subject: [PATCH] fix: alias --- packages/uni-cli-shared/src/easycom.ts | 4 ++-- packages/uni-h5/dist/uni-h5.cjs.js | 4 ++-- packages/uni-h5/dist/uni-h5.es.js | 12 ++++++------ packages/uni-h5/vite.config.ts | 3 +++ packages/vite-plugin-uni/src/config/resolve.ts | 16 ++++++++++++---- packages/vite-plugin-uni/src/index.ts | 4 ++-- 6 files changed, 27 insertions(+), 16 deletions(-) diff --git a/packages/uni-cli-shared/src/easycom.ts b/packages/uni-cli-shared/src/easycom.ts index d10a4c3c2..e8e2e64ac 100644 --- a/packages/uni-cli-shared/src/easycom.ts +++ b/packages/uni-cli-shared/src/easycom.ts @@ -172,13 +172,13 @@ function initAutoScanEasycom( if (!isDir(folder)) { return } - const importDir = slash(path.relative(rootDir, folder)) + const importDir = slash(folder) const files = fs.readdirSync(folder) // 读取文件夹文件列表,比对文件名(fs.existsSync在大小写不敏感的系统会匹配不准确) for (let i = 0; i < extensions.length; i++) { const ext = extensions[i] if (files.includes(name + ext)) { - easycoms[`^${name}$`] = `@/${importDir}/${name}${ext}` + easycoms[`^${name}$`] = `${importDir}/${name}${ext}` break } } diff --git a/packages/uni-h5/dist/uni-h5.cjs.js b/packages/uni-h5/dist/uni-h5.cjs.js index e5ce54d6f..1da8e8a44 100644 --- a/packages/uni-h5/dist/uni-h5.cjs.js +++ b/packages/uni-h5/dist/uni-h5.cjs.js @@ -9643,7 +9643,7 @@ const setNavigationBarTitle = /* @__PURE__ */ defineAsyncApi(API_SET_NAVIGATION_ }, SetNavigationBarTitleProtocol); require("localstorage-polyfill"); global.XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest; -var api = /* @__PURE__ */ Object.freeze({ +var api = { __proto__: null, [Symbol.toStringTag]: "Module", setNavigationBarTitle, @@ -9659,7 +9659,7 @@ var api = /* @__PURE__ */ Object.freeze({ getStorageInfoSync, getStorageInfo, getSystemInfoSync -}); +}; const uni$1 = api; const UniServiceJSBridge$1 = /* @__PURE__ */ shared.extend(ServiceJSBridge, { publishHandler(event, args, pageId) { diff --git a/packages/uni-h5/dist/uni-h5.es.js b/packages/uni-h5/dist/uni-h5.es.js index 3e47791e5..290136645 100644 --- a/packages/uni-h5/dist/uni-h5.es.js +++ b/packages/uni-h5/dist/uni-h5.es.js @@ -1177,12 +1177,12 @@ function normalizeTouchEvent(touches, top) { } return res; } -var instance = /* @__PURE__ */ Object.freeze({ +var instance = { __proto__: null, [Symbol.toStringTag]: "Module", $nne, createNativeEvent -}); +}; const CLASS_RE = /^\s+|\s+$/g; const WXS_CLASS_RE = /\s+/; function getWxsClsArr(clsArr, classList, isAdd) { @@ -1456,7 +1456,7 @@ function selectComponent(selector) { function selectAllComponents(selector) { return querySelectorAll(this, selector); } -var wxInstance = /* @__PURE__ */ Object.freeze({ +var wxInstance = { __proto__: null, [Symbol.toStringTag]: "Module", createSelectorQuery: createSelectorQuery$1, @@ -1464,7 +1464,7 @@ var wxInstance = /* @__PURE__ */ Object.freeze({ createIntersectionObserver: createIntersectionObserver$1, selectComponent, selectAllComponents -}); +}; function getOpenerEventChannel() { { if (this.$route) { @@ -18977,7 +18977,7 @@ const API_LOGIN = "login"; const login = /* @__PURE__ */ defineAsyncApi(API_LOGIN, createUnsupportedAsyncApi(API_LOGIN)); const API_GET_PROVIDER = "getProvider"; const getProvider = /* @__PURE__ */ defineAsyncApi(API_GET_PROVIDER, createUnsupportedAsyncApi(API_GET_PROVIDER)); -var api = /* @__PURE__ */ Object.freeze({ +var api = { __proto__: null, [Symbol.toStringTag]: "Module", upx2px, @@ -19119,7 +19119,7 @@ var api = /* @__PURE__ */ Object.freeze({ addPhoneContact, login, getProvider -}); +}; const CONTEXT_ID = "MAP_LOCATION"; const ICON_PATH = ""; var MapLocation = /* @__PURE__ */ defineSystemComponent({ diff --git a/packages/uni-h5/vite.config.ts b/packages/uni-h5/vite.config.ts index 390c14e6c..1a54798bf 100644 --- a/packages/uni-h5/vite.config.ts +++ b/packages/uni-h5/vite.config.ts @@ -116,6 +116,9 @@ export default defineConfig({ }, assetsDir: '.', rollupOptions: { + output: { + freeze: false, // uni 对象需要可被修改 + }, external(source) { if ( [ diff --git a/packages/vite-plugin-uni/src/config/resolve.ts b/packages/vite-plugin-uni/src/config/resolve.ts index acfad9616..f0b4fd40b 100644 --- a/packages/vite-plugin-uni/src/config/resolve.ts +++ b/packages/vite-plugin-uni/src/config/resolve.ts @@ -1,3 +1,4 @@ +import path from 'path' import { UserConfig } from 'vite' import { EXTNAME_VUE } from '@dcloudio/uni-cli-shared' import { VitePluginUniResolvedOptions } from '..' @@ -7,10 +8,17 @@ export function createResolve( _config: UserConfig ): UserConfig['resolve'] { return { - // alias: { - // '@': '', - // '~@': '', // src: url('~@/static/uni.ttf') format('truetype'); - // }, + // 必须使用alias解析,插件定制的resolveId,不会被应用到css等预处理器中 + alias: [ + // @ts-ignore because @rollup/plugin-alias' type doesn't allow function + // replacement, but its implementation does work with function values. + { + find: /^(~@|@)\/(.*)/, + replacement(_str: string, _$1: string, $2: string) { + return path.resolve(options.inputDir, $2) + }, + }, + ], extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json'].concat( EXTNAME_VUE ), diff --git a/packages/vite-plugin-uni/src/index.ts b/packages/vite-plugin-uni/src/index.ts index a2a9dedf0..6cde3d2eb 100644 --- a/packages/vite-plugin-uni/src/index.ts +++ b/packages/vite-plugin-uni/src/index.ts @@ -14,7 +14,7 @@ import { createConfigResolved } from './configResolved' import { createConfigureServer } from './configureServer' import { initExtraPlugins } from './utils' import { initPluginVueOptions } from './vue' -import { createResolveId } from './resolveId' +// import { createResolveId } from './resolveId' const debugUni = debug('vite:uni:plugin') @@ -93,7 +93,7 @@ export default function uniPlugin( plugins.push({ name: 'vite:uni', config: createConfig(options, uniPlugins), - resolveId: createResolveId(options), + // resolveId: createResolveId(options), configResolved: createConfigResolved(options), configureServer: createConfigureServer(options), }) -- GitLab