欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3實(shí)現(xiàn)頁面截圖功能示例詳解

 更新時間:2024年10月25日 09:53:02   作者:小菜又鳥  
在Vue3項目中實(shí)現(xiàn)頁面截圖的功能,可以通過使用js-web-screen-shot組件來實(shí)現(xiàn),本文以toolbox.js作為案例,詳細(xì)介紹了如何在Vue3框架下,利用js-web-screen-shot組件實(shí)現(xiàn)頁面截圖的具體步驟和方法,這一技術(shù)的應(yīng)用,不僅可以提高用戶體驗(yàn),還能在需要時方便地獲取頁面的即時信息

項目場景:

vue3實(shí)現(xiàn)頁面截圖功能

描述

使用 js-web-screen-shot 組件

結(jié)果

解決方案:

頁面:

<cut ref="cutRef" @getCut="getCutValue"></cut>
<div
  ref="textarea"
  class="input_message"
  contenteditable="true"
></div>
import { ref} from "vue";
import cut from "../../toolbox/cut/index.vue";
import { createElementImg } from "../../../utils/base/toolbox";
const cutRef = ref(null);
// 功能區(qū)--頁面截圖
const getCutValue = (e) => {
  createElementImg(e, textarea.value);
};

toolbox.js

//創(chuàng)建img
const createElementImg = (e, vnode, w = 200, h = 0) => {
  const img = document.createElement("img");
  img.src = e;
  img.alt = "圖片加載失敗";
  img.width = w;
  if (h) {
    img.height = h;
  }
  vnode.appendChild(img);
};
export { createElementImg };

組件

<template>
  <div></div>
</template>
<script setup>
import { ref } from "vue";
import ScreenShort from "js-web-screen-shot";
import { defineEmits } from "vue";
// 定義 emit 事件
const emit = defineEmits();
const exportimg = ref("");
// 按鈕點(diǎn)擊時間方法,構(gòu)建插件對象
const btnClick = () => {
  // 更多參數(shù) 和使用可以看它包里面的README.md文件
  const screenShotHandler = new ScreenShort({
    // 是否啟用webrtc,值為boolean類型,值為false則使用html2canvas來截圖
    enableWebRtc: false,
    // 層級級別,這個要比頁面上其他元素的z-index的值大
    level: 2001,
    completeCallback: callback, // 截圖成功完成的回調(diào)
    closeCallback: closeFn, // 截圖取消的回調(diào)
  });
};
const callback = (base64data) => {
  var image = new Image();
  image.src = base64data.base64;
  image.onload = () => {
    var canvas = convertImageToCanvas(image);
    var url = canvas.toDataURL("image/jpeg"); // base64編碼的圖片
    // 通過atob將base64進(jìn)行編碼
    var bytes = window.atob(url.split(",")[1]);
    // 處理異常,將ASCII碼小于0的轉(zhuǎn)換為大于0,進(jìn)行二進(jìn)制轉(zhuǎn)換
    var buffer = new ArrayBuffer(bytes.length);
    // 生成一個8位數(shù)的數(shù)組
    var uint = new Uint8Array(buffer);
    for (var j = 0; j < bytes.length; j++) {
      uint[j] = bytes.charCodeAt(j); // 根據(jù)長度返回相對應(yīng)的Unicode 編碼
    }
    // Blob對象  // type 為圖片的格式
    const blodImg = new Blob([buffer], { type: "image/jpeg" });
    exportimg.value = URL.createObjectURL(blodImg);
    emit("getCut", exportimg.value); // 觸發(fā)事件并傳遞數(shù)據(jù)
  };
};
const convertImageToCanvas = (image) => {
  var canvas = document.createElement("canvas");
  canvas.width = image.width;
  canvas.height = image.height;
  canvas.getContext("2d").drawImage(image, 0, 0);
  return canvas;
};
const closeFn = () => {
  // 取消截圖的回調(diào)
};
defineExpose({
  btnClick,
  callback,
  convertImageToCanvas,
  closeFn,
});
</script>
<style scoped></style>

到此這篇關(guān)于vue3實(shí)現(xiàn)頁面截圖功能的文章就介紹到這了,更多相關(guān)vue3 頁面截圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解vue-router 2.0 常用基礎(chǔ)知識點(diǎn)之導(dǎo)航鉤子

    詳解vue-router 2.0 常用基礎(chǔ)知識點(diǎn)之導(dǎo)航鉤子

    本篇文章主要介紹了vue-router 2.0 常用基礎(chǔ)知識點(diǎn)之導(dǎo)航鉤子,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Vue 購物車案例練習(xí)

    Vue 購物車案例練習(xí)

    這篇文章主要給大家分享關(guān)于Vue 購物車案例的小練習(xí),文章個悲劇購物車為標(biāo)題需求利用HTML代碼實(shí)現(xiàn)整個過程,需要的朋友可以參考一下文章的具體內(nèi)容
    2021-10-10
  • 通過vue刷新左側(cè)菜單欄操作

    通過vue刷新左側(cè)菜單欄操作

    這篇文章主要介紹了通過vue刷新左側(cè)菜單欄操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue自定義指令實(shí)現(xiàn)彈窗拖拽四邊拉伸及對角線拉伸效果

    Vue自定義指令實(shí)現(xiàn)彈窗拖拽四邊拉伸及對角線拉伸效果

    小編最近在做一個vue前端項目,需要實(shí)現(xiàn)彈窗的拖拽,四邊拉伸及對角線拉伸,以及彈窗邊界處理功能,本文通過實(shí)例代碼給大家分享我的實(shí)現(xiàn)過程及遇到問題解決方法,感興趣的朋友一起看看吧
    2021-08-08
  • vue項目引入antDesignUI組件實(shí)現(xiàn)

    vue項目引入antDesignUI組件實(shí)現(xiàn)

    本文介紹了如何以Vue引入antDesignUI,主要包括下載安裝、配置和引入組件等步驟,通過本文,讀者可以快速了解antDesignUI在Vue中的應(yīng)用,感興趣的可以了解一下
    2023-08-08
  • iview實(shí)現(xiàn)select tree樹形下拉框的示例代碼

    iview實(shí)現(xiàn)select tree樹形下拉框的示例代碼

    這篇文章主要介紹了iview實(shí)現(xiàn)select tree樹形下拉框的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • vue?Keep-alive組件緩存的簡單使用代碼

    vue?Keep-alive組件緩存的簡單使用代碼

    keep-alive是Vue提供的一個抽象組件,用來對組件進(jìn)行緩存,從而節(jié)省性能,下面這篇文章主要給大家介紹了關(guān)于vue?Keep-alive組件緩存的簡單使用,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vue各種loader的基本配置與使用示例教程

    Vue各種loader的基本配置與使用示例教程

    這篇文章主要介紹了Vue?各種loader的基本配置與使用,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • vue+element實(shí)現(xiàn)動態(tài)加載表單

    vue+element實(shí)現(xiàn)動態(tài)加載表單

    這篇文章主要為大家詳細(xì)介紹了vue+element實(shí)現(xiàn)動態(tài)加載表單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • vue中v-cloak的作用和原理解析

    vue中v-cloak的作用和原理解析

    v-cloak原理是先通過樣式隱藏內(nèi)容,然后在內(nèi)存中進(jìn)行值的替換,將替換的內(nèi)容再反饋給界面,數(shù)據(jù)渲染完場之后,v-cloak 屬性會被自動去除,本文詳細(xì)介紹vue中v-cloak的作用和原理解析,感興趣的朋友一起看看吧
    2023-09-09

最新評論