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

Vue3中JSON字符串轉(zhuǎn)對象的常用方法小結(jié)

 更新時(shí)間:2025年09月23日 10:05:09   作者:BillKu  
這篇文章主要介紹了Vue3中將JSON字符串轉(zhuǎn)對象的三種方法:推薦使用JSON.parse(),安全且性能好,但需嚴(yán)格格式和錯(cuò)誤處理;eval()不推薦,因安全風(fēng)險(xiǎn)和性能差,建議始終用try...catch包裹,確保應(yīng)用穩(wěn)健,需要的朋友可以參考下

JSON 字符串轉(zhuǎn)對象方法

1. 使用 JSON.parse()(推薦)

JSON.parse() 是瀏覽器原生的方法,它能夠?qū)⒎?JSON 格式的字符串轉(zhuǎn)換為 JavaScript 對象。

const jsonString = '{"name": "John", "age": 30, "city": "New York"}';
// 使用 JSON.parse() 進(jìn)行轉(zhuǎn)換
const jsonObject = JSON.parse(jsonString);
console.log(jsonObject.name); // 輸出: John

重要:添加錯(cuò)誤處理

JSON 字符串格式必須嚴(yán)格合法(例如,屬性名必須用雙引號括起來),否則 JSON.parse() 會拋出錯(cuò)誤。務(wù)必使用 try...catch 進(jìn)行錯(cuò)誤處理

let jsonObject;
try {
  jsonObject = JSON.parse(jsonString);
  console.log('轉(zhuǎn)換成功', jsonObject);
} catch (error) {
  console.error("JSON 解析失敗:", error);
  // 在這里可以進(jìn)行容錯(cuò)處理,例如設(shè)置一個(gè)默認(rèn)空對象
  jsonObject = {};
}

2. 使用 eval()(不推薦,了解即可)

eval() 函數(shù)可以執(zhí)行字符串中的 JavaScript 代碼,因此也能解析 JSON 字符串。

const jsonString = '{"name": "John", "age": 30, "city": "New York"}';
const jsonObject = eval('(' + jsonString + ')'); // 注意這里的括號
console.log(jsonObject);

為什么不推薦 eval()?

  • 安全性風(fēng)險(xiǎn)eval() 會執(zhí)行字符串中的任何代碼。如果字符串來源不可信(例如來自用戶輸入或第三方),可能包含惡意腳本,導(dǎo)致嚴(yán)重的安全漏洞(XSS 攻擊)。
  • 性能較差eval() 的執(zhí)行速度通常比 JSON.parse() 慢。

因此,除非有特殊理由并且你能完全控制字符串來源,否則請始終使用 JSON.parse()。

3. 在 Vue 組件中的使用示例

在實(shí)際的 Vue 3 組件中,你可能會在 生命周期鉤子、方法 或 計(jì)算屬性 中進(jìn)行轉(zhuǎn)換。

示例:處理來自 API 的 JSON 數(shù)據(jù)

許多時(shí)候,JSON 字符串來源于后端 API 的響應(yīng)。

<template>
  <div>
    <h1>User Info</h1>
    <p v-if="user">Name: {{ user.name }}</p>
    <p v-if="user">Age: {{ user.age }}</p>
    <p v-if="user">City: {{ user.city }}</p>
    <p v-else>Loading...</p>
  </div>
</template>

<script>
import { ref, onMounted } from 'vue';

export default {
  setup() {
    const user = ref(null); // 初始值為 null

    onMounted(async () => {
      // 模擬從 API 獲取到一個(gè) JSON 字符串
      const responseJsonString = '{"name": "Alice", "age": 25, "city": "London"}';

      try {
        // 1. 將字符串解析為對象
        const userData = JSON.parse(responseJsonString);
        // 2. 將響應(yīng)式變量賦值
        user.value = userData;
      } catch (error) {
        console.error("Error parsing JSON:", error);
        // 處理錯(cuò)誤,例如設(shè)置一個(gè)默認(rèn)用戶對象或顯示錯(cuò)誤信息
        user.value = { name: 'Unknown', age: 0, city: 'Nowhere' };
      }
    });

    return {
      user
    };
  }
};
</script>

示例:使用計(jì)算屬性(Computed)

如果字符串是響應(yīng)式的(例如來自 ref 或 reactive),你可以使用計(jì)算屬性自動(dòng)進(jìn)行轉(zhuǎn)換和派生。

<template>
  <div>
    <p>Name: {{ userObject?.name }}</p>
    <p>Age: {{ userObject?.age }}</p>
  </div>
</template>

<script>
import { ref, computed } from 'vue';

export default {
  setup() {
    const jsonString = ref('{"name": "Bob", "age": 40}');

    const userObject = computed(() => {
      try {
        return JSON.parse(jsonString.value);
      } catch (error) {
        console.error("Computed property parsing failed:", error);
        return null;
      }
    });

    return {
      userObject
    };
  }
};
</script>

注意事項(xiàng)

嚴(yán)格的 JSON 格式JSON.parse() 要求字符串必須是標(biāo)準(zhǔn)的 JSON 格式。

  • ? 正確:'{"name": "John", "age": 30}' (鍵和字符串值都用雙引號)
  • ? 錯(cuò)誤:"{name: 'John', age: 30}" (鍵沒有引號,值用了單引號)

安全性:始終對要解析的字符串來源保持警惕,特別是對于來自用戶輸入或第三方 API 的數(shù)據(jù)。使用 try...catch 是防止應(yīng)用崩潰的關(guān)鍵。

Vue 的響應(yīng)性:使用 JSON.parse() 返回的是一個(gè)普通對象,你需要將其賦值給 Vue 的響應(yīng)式變量(如 ref 或 reactive)才能在模板中觸發(fā)更新。

qs 庫并非用于此場景:搜索結(jié)果中提到的 qs 庫主要用于解析 URL 查詢字符串 (如 a=1&b=2),而不是標(biāo)準(zhǔn)的 JSON 字符串。處理標(biāo)準(zhǔn) JSON,JSON.parse() 就夠了。

總結(jié)

方法推薦度優(yōu)點(diǎn)缺點(diǎn)適用場景
JSON.parse()★★★★★標(biāo)準(zhǔn)、安全、性能好要求嚴(yán)格的 JSON 格式絕大多數(shù)場景
eval()★☆☆☆☆能解析非標(biāo)準(zhǔn)格式極高安全風(fēng)險(xiǎn)、性能差、需謹(jǐn)慎處理括號應(yīng)避免,僅在極端受控環(huán)境下

記住這個(gè)最佳實(shí)踐:堅(jiān)持使用 JSON.parse() 并始終用 try...catch 塊包裹它。這能確保你的 Vue 3 應(yīng)用既健壯又安全。

到此這篇關(guān)于Vue3中JSON字符串轉(zhuǎn)對象的常用方法小結(jié)的文章就介紹到這了,更多相關(guān)Vue3 JSON字符串轉(zhuǎn)對象內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue設(shè)置頁面背景及背景圖片簡單示例

    vue設(shè)置頁面背景及背景圖片簡單示例

    這篇文章主要給大家介紹了關(guān)于vue設(shè)置頁面背景及背景圖片的相關(guān)資料,在Vue項(xiàng)目開發(fā)中我們經(jīng)常要向頁面中添加背景圖片,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • vue動(dòng)態(tài)綁定組件子父組件多表單驗(yàn)證功能的實(shí)現(xiàn)代碼

    vue動(dòng)態(tài)綁定組件子父組件多表單驗(yàn)證功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue動(dòng)態(tài)綁定組件子父組件多表單驗(yàn)證功能的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2018-05-05
  • Vue 樣式切換及三元判斷樣式關(guān)聯(lián)操作

    Vue 樣式切換及三元判斷樣式關(guān)聯(lián)操作

    這篇文章主要介紹了Vue 樣式切換及三元判斷樣式關(guān)聯(lián)操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 利用Vue3實(shí)現(xiàn)一個(gè)可以用js調(diào)用的組件

    利用Vue3實(shí)現(xiàn)一個(gè)可以用js調(diào)用的組件

    最近遇到個(gè)功能要求,想要在全局中調(diào)用組件,而且要在某些js文件內(nèi)調(diào)用,所以這篇文章主要給大家介紹了關(guān)于如何利用Vue3實(shí)現(xiàn)一個(gè)可以用js調(diào)用的組件的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • vue 點(diǎn)擊按鈕增加一行的方法

    vue 點(diǎn)擊按鈕增加一行的方法

    今天小編就為大家分享一篇vue 點(diǎn)擊按鈕增加一行的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 基于Vue實(shí)現(xiàn)可以拖拽的樹形表格實(shí)例詳解

    基于Vue實(shí)現(xiàn)可以拖拽的樹形表格實(shí)例詳解

    因業(yè)務(wù)需求,需要一個(gè)樹形表格,并且支持拖拽排序,任意未知插入,github搜了下,真不到合適的,大部分樹形表格都沒有拖拽功能,所以決定自己實(shí)現(xiàn)一個(gè)。這里分享一下實(shí)現(xiàn)過程,需要的朋友可以參考下
    2018-10-10
  • vue實(shí)現(xiàn)拖拽滑動(dòng)分割面板

    vue實(shí)現(xiàn)拖拽滑動(dòng)分割面板

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)拖拽滑動(dòng)分割面板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • VUE腳手架具體使用方法

    VUE腳手架具體使用方法

    這篇文章主要介紹了VUE腳手架具體使用方法,vue-cli這個(gè)構(gòu)建工具大大降低了webpack的使用難度,小編覺得不錯(cuò),下面就一起來了解一下具體使用方法
    2019-05-05
  • Vue組件中的父子組件使用

    Vue組件中的父子組件使用

    這篇文章主要介紹了Vue組件中的父子組件使用,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue.js出現(xiàn)Vue.js?not?detected錯(cuò)誤的解決方案

    vue.js出現(xiàn)Vue.js?not?detected錯(cuò)誤的解決方案

    這篇文章主要介紹了vue.js出現(xiàn)Vue.js?not?detected錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09

最新評論