中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue如何設置圖片不轉為base64

發布時間:2022-02-09 11:30:11 來源:億速云 閱讀:435 作者:小新 欄目:開發技術

這篇文章主要介紹了Vue如何設置圖片不轉為base64,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Vue設置圖片不轉為base64

在使用 Vue.js 框架開發項目時,vue-cli創建的webpack模板默認會將10K以下的圖片和字體文件轉為base64。

好處:帶來了更快的渲染,不會因為頁面切換時還有加載圖片的延遲感。

壞處:打包后的CSS,JS文件非常大,特別是圖片數量多的情況下,這個問題尤為明顯。

vue-cli 3 、vue-cli 4  版本

修改文件:vue.config.js

源碼如下

module.exports = {
    // ...
    /* 調整內聯文件的大小限制,讓小圖片不轉為base64 */
    chainWebpack: config => {
        config.module
            .rule('images')
            .use('url-loader')
            .loader('url-loader')
            .tap(options => Object.assign(options, { limit: 1 }))
    },
    // ...
}

vue-cli 2 版本

修改文件:/build/webpack.base.conf.js

修改方式,如下圖所示位置,將圖片和字體的 limit(限制)修改為:1(0貌似無效),修改后文件都不會再被轉為base64格式了。

Vue如何設置圖片不轉為base64

Vue項目base64轉img

最近一個vue項目中,有個需求是, 發送消息是base64時,轉換成圖片預覽發送出去。

輸入框

<el-input
        class="input-box"
        ref="elInputText"
        type="textarea"
        v-model="content"
        @paste.native="onPasteEvent"
        @keydown.native.enter.prevent="handlerKeyupEnter"
      ></el-input>

設定一個 dialog 彈框。

<!-- 圖片預覽dialog -->
    <el-dialog
      title="圖片預覽"
      :visible.sync="previewImgObj.show"
      v-if="previewImgObj.show"
      append-to-body
    >
      <img
        width="100%"
        v-if="previewImgObj.imgUrl"
        class="ly-margin-center"
        :src="previewImgObj.imgUrl"
        v-image-view
      />
      <span slot="footer" class="dialog-footer">
        <el-button @click="previewImgObj.show = false">取 消</el- button>
        <el-button type="primary" @click="sendBase64ImgMessge">確 定</el-button>
      </span>
    </el-dialog>
// 監聽粘貼事件
    async onPasteEvent(e) {
      e.preventDefault();
      let data = await addEventPasteListener(e);
       if (data.type === "string") {
        // 復制某條消息
        if (!data.string) return;
        // console.log(data.string)
        // 正則表達式判斷data是否是base64
        function validDataUrl(s) {
          return validDataUrl.regex.test(s);
        }
        validDataUrl.regex = /^\s*data:([a-z]+\/[a-z0-9-+.]+(;[a-z-]+=[a-z0-9-]+)?)?(;base64)?,([a-z0-9!$&',()*+;=\-._~:@\/?%\s]*?)\s*$/i;
        // 如果是base64轉換成圖片預覽
        if (validDataUrl(data.string)) {
          let that = this;
          function previwImg(item) {
            that.previewImgObj = {
              show: true,
              imgUrl: item
            };
          }
          previwImg(data.string);
        }
     }

效果展示

Vue如何設置圖片不轉為base64

Vue如何設置圖片不轉為base64

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Vue如何設置圖片不轉為base64”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴青县| 翁源县| 台东县| 嵊州市| 泰州市| 天津市| 石门县| 阿拉善右旗| 松溪县| 石渠县| 磐石市| 额敏县| 德惠市| 宁安市| 富源县| 宁陕县| 青州市| 罗田县| 宜黄县| 石柱| 锦屏县| 定州市| 融水| 崇信县| 西盟| 正宁县| 江门市| 延边| 尼勒克县| 离岛区| 田阳县| 繁峙县| 穆棱市| 陵水| 林周县| 三门县| 普安县| 北票市| 怀化市| 南宫市| 龙岩市|