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

vue最簡單的前后端交互示例詳解

 更新時間:2018年10月11日 09:24:50   作者:長河漸落曉星沉  
這篇文章主要介紹了vue最簡單的前后端交互示例詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

一、學習 vue 面臨的問題

最近想學一門前端技術防身,看到博客園中寫 vue 的多,那就 vue 吧。都說 vue 的官方教程寫得好,所以我就從官方教程開始學習。官方教程說“Vue (讀音 /vjuː/,類似于 view) 是一套用于構建用戶界面的漸進式框架。與其它大型框架不同的是,Vue 被設計為可以自底向上逐層應用?!钡沁@個概念是個什么鬼?還是讓人一頭霧水嘛。而且我一開始也沒有搞清楚 vue 的定位,只知道它是一個前端庫,但是確實不知道它的優(yōu)勢是什么,還以為它是一個學會就能一勞永逸的萬能的框架呢。官方教程一開始就講怎么綁定頁面上的元素和 JavaScript 中的數(shù)據(jù),而且是雙向綁定,自動更新,功能確實很強大。但是遲遲沒有講怎么和服務器端進行交互,怎么獲取服務器端的數(shù)據(jù)。(后來經(jīng)過反復閱讀教程,才發(fā)現(xiàn)其實它一開始就說了“Vue 的核心庫只關注視圖層”,是我自己忽略了。)

二、最簡單的前后段交互示例

吹再多的口水,也不如一個能運行的示例來得實在。這個例子也是從 vue 的官方教程中抄來的。首先,先建立一個 index.html 文件,編輯其內(nèi)容,如下:

<!DOCTYPE html>
<html>
<head>
 <title>My first Vue app</title>
 <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
 <script src="https://cdn.jsdelivr.net/npm/axios@0.12.0/dist/axios.min.js"></script>
 <script src="https://cdn.jsdelivr.net/npm/lodash@4.13.1/lodash.min.js"></script>
</head>
<body>
 <div id="watch-example">
  <p>
   Ask a yes/no question:
   <input v-model="question">
  </p>
  <p>{{ answer }}</p>
 </div>

 <script>
  var watchExampleVM = new Vue({
   el: '#watch-example',
   data: {
    question: '',
    answer: 'I cannot give you an answer until you ask a question!'
   },
   watch: {
    // 如果 question 發(fā)生改變,這個函數(shù)就會運行
    question: function (newQuestion, oldQuestion) {
     this.answer = 'Waiting for you to stop typing...'
     this.debouncedGetAnswer()
    }
   },
   created: function () {
    // `_.debounce` 是一個通過 Lodash 限制操作頻率的函數(shù)。
    // 在這個例子中,我們希望限制訪問 yesno.wtf/api 的頻率
    // AJAX 請求直到用戶輸入完畢才會發(fā)出。想要了解更多關于
    // `_.debounce` 函數(shù) (及其近親 `_.throttle`) 的知識,
    // 請參考:https://lodash.com/docs#debounce
    this.debouncedGetAnswer = _.debounce(this.getAnswer, 500)
   },
   methods: {
    getAnswer: function () {
     if (this.question.indexOf('?') === -1) {
      this.answer = 'Questions usually contain a question mark. ;-)'
      return
     }
     this.answer = 'Thinking...'
     var vm = this
     axios.get('https://yesno.wtf/api')
      .then(function (response) {
       vm.answer = _.capitalize(response.data.answer)
      })
      .catch(function (error) {
       vm.answer = 'Error! Could not reach the API. ' + error
      })
    }
   }
  })
 </script>
</body>
</html>

然后使用 chromium 瀏覽器打開這個文件。下面是運行效果:

這里訪問的后端是 https://yesno.wtf/api ,它傳回的數(shù)據(jù)時 json 格式的,如果直接訪問它,得到的結果如下:

https://yesno.wtf 這是一個神奇的網(wǎng)站,當你對某件事拿不定注意,需要別人推你一把時,可以訪問它,它會隨機返回一個 gif 動畫,點頭表示 yes,搖頭表示 no,幫你做這個艱難的決定。直接訪問 https://yesno.wtf ,注意在地址欄中不帶 api 字樣,可以得到這樣的結果:

 

三、從這個示例,我學到了什么

首先,解答了我前面的疑惑,那就是怎么和后端交互。在這個示例中,它使用 axios 庫從 https://yesno.wtf/api 獲取數(shù)據(jù)。同時,在這個例子中,它還使用 lodash 限制刷新頻率。

其次,這個示例只有一個 html 文件,在這個文件中,使用

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script src="https://cdn.jsdelivr.net/npm/axios@0.12.0/dist/axios.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/lodash@4.13.1/lodash.min.js"></script>

引入需要的 vue.js、 axios.js 和 lodash.js,不需要下載安裝一些有的沒的東西,不需要學習在服務器端運行 JavaScript 的任何知識。本來嘛,我是準備學 .netcore 的,再讓我學個 nodejs 我也覺得不科學嘛。

最后,我知道了學習 vue 不是單純學習 vue,還要學習 axios.js 和服務器交互,真的要寫個產(chǎn)品,還少不了漂亮的 UI 界面啥的,所以還要學習和 vue 配套的 UI 框架,看來學習的路還很長。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • axios請求二次封裝之避免重復發(fā)送請求

    axios請求二次封裝之避免重復發(fā)送請求

    在做vue中大型項目的時候,官方推薦使用axios,但是原生的axios可能對項目的適配不友好,所以在工程開始的來封裝一下axios,下面這篇文章主要給大家介紹了關于axios請求二次封裝之避免重復發(fā)送請求的相關資料,需要的朋友可以參考下
    2022-10-10
  • vue導出html、word和pdf的實現(xiàn)代碼

    vue導出html、word和pdf的實現(xiàn)代碼

    這篇文章主要介紹了vue導出html、word和pdf的實現(xiàn)方法,文中完成了三種文件的導出但是還有很多種方法,小編就不給大家一一列舉了,需要的朋友可以參考下
    2018-07-07
  • vue使用高德地圖根據(jù)坐標定位點的實現(xiàn)代碼

    vue使用高德地圖根據(jù)坐標定位點的實現(xiàn)代碼

    這篇文章主要介紹了vue使用高德地圖根據(jù)坐標定位點的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • 基于vue3+antDesign2+echarts?實現(xiàn)雷達圖效果

    基于vue3+antDesign2+echarts?實現(xiàn)雷達圖效果

    這篇文章主要介紹了基于vue3+antDesign2+echarts?實現(xiàn)雷達圖,本文通過實例代碼圖文相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • vue組件父子間通信詳解(三)

    vue組件父子間通信詳解(三)

    這篇文章主要為大家詳細介紹了vue組件父子間通信的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 解決vant框架做H5時踩過的坑(下拉刷新、上拉加載等)

    解決vant框架做H5時踩過的坑(下拉刷新、上拉加載等)

    這篇文章主要介紹了解決vant框架做H5時踩過的坑(下拉刷新、上拉加載等),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Nuxt.js結合Serverless構建無服務器應用

    Nuxt.js結合Serverless構建無服務器應用

    Nuxt.js是一個基于Vue.js的框架,結合Serverless架構,Nuxt.js可以讓你構建高度可擴展、成本效益高的無服務器應用,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • vue3新擬態(tài)組件庫開發(fā)流程之table組件源碼分析

    vue3新擬態(tài)組件庫開發(fā)流程之table組件源碼分析

    這篇文章主要介紹了vue3新擬態(tài)組件庫開發(fā)流程——table組件源碼,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • 關于element-ui表單中限制輸入純數(shù)字的解決方式

    關于element-ui表單中限制輸入純數(shù)字的解決方式

    這篇文章主要介紹了關于element-ui表單中限制輸入純數(shù)字的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • VUE3 加載自定義SVG文件的詳細步驟

    VUE3 加載自定義SVG文件的詳細步驟

    要在 Vue 項目中使用 svg-sprite-loader 來管理 SVG 圖標,需要執(zhí)行相應的步驟,接下來通過本文給大家介紹VUE3 加載自定義SVG文件的詳細步驟,感興趣的朋友一起看看吧
    2024-01-01

最新評論