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

Tauri?打開本地文件踩坑分析解決

 更新時(shí)間:2023年04月14日 14:29:17   作者:用戶7612655850794  
這篇文章主要為大家介紹了Tauri?打開本地文件踩坑分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

Tauri 打開本地文件踩坑

最近我在嘗試使用Tauri,遇到一個(gè)問題,其實(shí)從事后來看,如果熟悉Tauri的api的話,是件分分鐘就能解決的事情,但由于思維慣性,實(shí)際卻困擾了我一整天,寫文記錄一下我踩坑的過程。

需求

需求很簡(jiǎn)單,就是打開本地圖片進(jìn)行展示,同時(shí)還要能拿到圖片在本地的絕對(duì)路徑。

  • 展示圖片
  • 拿到絕對(duì)路徑

<input type="file" >存在的問題

最先想到辦法,當(dāng)然是使用input元素,這是前端讀取本地文件的常規(guī)方案,而且我曾經(jīng)使用electron實(shí)現(xiàn)過一樣的功能,大致就是:

<input type="file" id="file-selector" />
document.getElementById("file-selector").addEventListener('change', e => {
    const files = e.target.files
    files.forEach(file => {
        const url = URL.createObjectURL(file)
        const path = file.path
    })
})

但遺憾的是,Tauri的File對(duì)象并沒有實(shí)現(xiàn)path這個(gè)屬性。

出于安全考慮,瀏覽器并沒有提供File對(duì)象的絕對(duì)路徑,pathelectron自己提供的:electron/file-object.md at main · electron/electron (github.com)。

隨后,盡管想了各種辦法,比如引入file-selector之類的,但最終的結(jié)論是:input拿不到文件的絕對(duì)路徑。

Dialog打開文件

我在心里吐槽“Tauri果然是不如electron”之后,我決定去Github上搜一下issue,不出所料,不只我一個(gè)人遇到這個(gè)問題:

Getting a real path of file type input · Issue #87

這里面給出了一個(gè)拿到文件絕對(duì)路徑的辦法,那就是使用Dialog

首先在tauri.conf.json添加配置:

"allowlist": {
    "dialog": {
        "all": false,
        "open": true
    }
}

然后

import { open } from "@tauri/api/dialog"
async handler(){
  let file = await open()
}

open方法會(huì)像input file一樣打開一個(gè)文件選擇框,返回文件的絕對(duì)路徑。

如果想一次選擇多個(gè)文件,可以添加選項(xiàng):

let files = await open({ multiple: true })

實(shí)際嘗試發(fā)現(xiàn),這樣確實(shí)能拿到文件的絕對(duì)路徑,但也只有絕對(duì)路徑。

于是我就陷入了困境:通過input可以展示圖片,但拿不到絕對(duì)路徑,而dialog可以拿到絕對(duì)路徑,卻無法顯示圖片,因?yàn)榍岸藷o法直接通過一個(gè)本地的絕對(duì)路徑來展示圖片。

怎么辦呢?

fs讀取文件

于是,我開始考慮使用Tauri提供的fs API,利用絕對(duì)路徑來讀取文件內(nèi)容,然后再轉(zhuǎn)換成Blob對(duì)象。

配置tauri.conf.json

"allowlist": {
    "dialog": {
        "all": false,
        "open": true
    },
    "fs": {
        "all": false,
        "readFile": true,
    }
}

讀取文件并轉(zhuǎn)換:

import { readBinaryFile } from '@tauri-apps/api/fs';
import { open } from "@tauri/api/dialog"
async handler(){
  // 打開文件獲取絕對(duì)路徑
  let files = await open({ multiple: true })
  files.forEach(async filePath => {
      // 讀取二進(jìn)制文件
      const contents = await readBinaryFile(filePath)
      // 轉(zhuǎn)換為blob對(duì)象,然后轉(zhuǎn)換為url
      const blob = new Blob([contents])
      const url = URL.createObjectURL(blob)
  })
}

但是,正如我預(yù)期的那樣,這么做有嚴(yán)重的性能問題。

經(jīng)簡(jiǎn)單測(cè)試,打開100張圖片(每張400kb左右)需要好幾秒鐘才能完成,打開500張圖片更是花了約20秒才處理完畢。

而如果使用input file,500張圖片只要一兩秒就能搞定。

所以,雖然功能上已經(jīng)沒有問題,但性能問題無法忽視,看來還需要找找別的辦法。

最終解決辦法

經(jīng)過一整天的摸索,我最終找到了Tauri提供這個(gè)函數(shù):convertFileSrc,可以將一個(gè)絕對(duì)路徑轉(zhuǎn)換為類似于URL.createObjectURL那樣的URL。

值得一提的是,這個(gè)函數(shù)和最常用的 invoke處于同一個(gè)模塊內(nèi),而且在Tauri的文檔中,convertFileSrc甚至位于invoke之前,但我卻一直沒有注意到它,一方面是因?yàn)?,之前從沒有想過要使用絕對(duì)路徑來轉(zhuǎn)換URL,因?yàn)榧兦岸耸亲霾坏竭@一點(diǎn)的;另一方面,由于思維慣性,前端打開本地文件往往都是用的input file,遇到這個(gè)問題我一直想的是如何從input事件著手,沒有去仔細(xì)看文檔……這就是所謂的燈下黑嗎

首先,配置tauri.conf.json

{
    "allowlist": {
        "dialog": {
            "all": true,
            "open": true
        },
        "protocol": {
            "all": false,
            "asset": true,
            "assetScope": [
                "$PICTURE"
            ]
        }
    },
    "security": {
        "csp": "default-src 'self'; img-src 'self'; asset: https://asset.localhost"
    }
}

然后

import { convertFileSrc } from '@tauri-apps/api/tauri'
import { open } from "@tauri/api/dialog"
async handler(){
  let files = await open({ multiple: true })
  files.forEach(filePath =&gt; {
      const url = convertFileSrc(filePath)
  })
}

速度和HTML原生的input file差不多,雖然拿不到文件大小之類的信息,但至少我最需要的兩個(gè)需求可以實(shí)現(xiàn)了,只要有了絕對(duì)路徑,文件大小之類的可以交給Rust。

以上就是Tauri 打開本地文件踩坑分析解決的詳細(xì)內(nèi)容,更多關(guān)于Tauri 打開本地文件踩坑的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Rust中的方法

    詳解Rust中的方法

    方法其實(shí)就是結(jié)構(gòu)體的成員函數(shù),在C語(yǔ)言中的結(jié)構(gòu)體是沒有成員函數(shù)的,但是Rust畢竟也是一門面向?qū)ο蟮木幊陶Z(yǔ)言,所以給結(jié)構(gòu)體加上方法的特性很符合面向?qū)ο蟮奶攸c(diǎn),這篇文章主要介紹了Rust中的方法,需要的朋友可以參考下
    2022-10-10
  • 關(guān)于Rust?使用?dotenv?來設(shè)置環(huán)境變量的問題

    關(guān)于Rust?使用?dotenv?來設(shè)置環(huán)境變量的問題

    在項(xiàng)目中,我們通常需要設(shè)置一些環(huán)境變量,用來保存一些憑證或其它數(shù)據(jù),這時(shí)我們可以使用dotenv這個(gè)crate,接下來通過本文給大家介紹Rust?使用dotenv來設(shè)置環(huán)境變量的問題,感興趣的朋友一起看看吧
    2022-01-01
  • Rust生成隨機(jī)數(shù)的項(xiàng)目實(shí)踐

    Rust生成隨機(jī)數(shù)的項(xiàng)目實(shí)踐

    Rust標(biāo)準(zhǔn)庫(kù)中并沒有隨機(jī)數(shù)生成器,常見的解決方案是使用rand包,本文主要介紹了Rust生成隨機(jī)數(shù)的項(xiàng)目實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • Rust?實(shí)現(xiàn)?async/await的詳細(xì)代碼

    Rust?實(shí)現(xiàn)?async/await的詳細(xì)代碼

    異步編程在 Rust 中的地位非常高,很多 crate 尤其是多IO操作的都使用了 async/await,這篇文章主要介紹了Rust?如何實(shí)現(xiàn)?async/await,需要的朋友可以參考下
    2022-09-09
  • 使用Rust制作康威生命游戲的實(shí)現(xiàn)代碼

    使用Rust制作康威生命游戲的實(shí)現(xiàn)代碼

    這篇文章主要介紹了使用Rust制作康威生命游戲,初始rust項(xiàng)目,使用wasm的項(xiàng)目模板,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • Rust中引用的具體使用

    Rust中引用的具體使用

    在Rust語(yǔ)言中,引用機(jī)制是其所有權(quán)系統(tǒng)的重要組成部分,ust提供了兩種類型的引用,不可變引用和可變引用,本文就來詳細(xì)的介紹一下這兩種的用法,感興趣的可以了解一下
    2024-03-03
  • R語(yǔ)言ggplot2繪圖安裝與調(diào)試

    R語(yǔ)言ggplot2繪圖安裝與調(diào)試

    ggplot2是R語(yǔ)言中最常用的繪圖包之一,它提供了一種基于圖層的繪圖語(yǔ)法,使得用戶可以輕松地創(chuàng)建高質(zhì)量的數(shù)據(jù)可視化圖表。在使用ggplot2之前,需要先安裝該包并進(jìn)行調(diào)試。安裝ggplot2可以通過CRAN或GitHub進(jìn)行,調(diào)試則需要注意數(shù)據(jù)格式、語(yǔ)法錯(cuò)誤等問題。
    2023-06-06
  • Rust語(yǔ)言從入門到精通系列之Iterator迭代器深入詳解

    Rust語(yǔ)言從入門到精通系列之Iterator迭代器深入詳解

    這篇文章主要為大家介紹了Rust語(yǔ)言從入門到精通系列之Iterator迭代器深入詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Go調(diào)用Rust方法及外部函數(shù)接口前置

    Go調(diào)用Rust方法及外部函數(shù)接口前置

    這篇文章主要為大家介紹了Go調(diào)用Rust方法及外部函數(shù)接口前置示例實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • Rust調(diào)用函數(shù)操作符?.?和?::?的區(qū)別詳解

    Rust調(diào)用函數(shù)操作符?.?和?::?的區(qū)別詳解

    在Rust中,.和::操作符都可以用來調(diào)用方法,但它們的用法有所不同,所以本文就將詳細(xì)的給大家介紹一下.和::操作符的區(qū)別,感興趣的同學(xué)跟著小編一起來學(xué)習(xí)吧
    2023-07-07

最新評(píng)論