vue -- 網(wǎng)絡(luò)應(yīng)用 -- axios

axios 網(wǎng)絡(luò)請(qǐng)求庫

  • axios必須先導(dǎo)入后使用
  • 使用get或post方法即可發(fā)送對(duì)應(yīng)的請(qǐng)求
  • then方法中的回調(diào)函數(shù)會(huì)在請(qǐng)求成功或失敗時(shí)觸發(fā)
  • 通過回調(diào)函數(shù)的形參可以獲取相應(yīng)內(nèi)容,或錯(cuò)誤信息
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
image.png

image.png
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="vue.js" type="text/javascript" charset="utf-8"></script>
    <style>
    </style>
</head>
<body>
    <input type="button" value="get" class="get">
    <input type="button" value="post" class="post">
    <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
    <script>
        /*
        interface 1 : random joke
        address:
        method:get
        para:num
        response:joke
         */
        document.querySelector('.get').onclick = function () {
            axios.get('https://autumnfish.cn/api/joke/list?num=6')
            .then(function (response) {
                console.log(response)
            },function (err){
                console.log(err)
            } )
        }
        /*
        interface 2 : user register
        address:
        method:post
        para:username
        resopnse:success or fail
         */
        document.querySelector('.post').onclick = function () {
            axios.post('https://autumnfish.cn/api/user/reg',{
                username:'jack'
            }).then(function (response) {
                console.log(response)
            },function (err) {
                console.log(err)
            })
        }

    </script>
</body>
</html>

axios中文文檔:起步 | Axios 中文文檔 | Axios 中文網(wǎng) (axios-http.cn)

axios+vue

  • axios回調(diào)函數(shù)中的this已經(jīng)改變,無法訪問到data中的數(shù)據(jù)
  • 把this保存起來.回調(diào)函數(shù)值中直接使用保存的this即可


    image.png
<div id="app">
        <input type="button" value="get joke" @click="getJoke">
        <p>{{ joke }}</p>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
    <script type="text/javascript">
        var app = new Vue({
            el:'#app',
            data:{
                joke:'funny joke'
            },
            methods:{
                getJoke:function () {
                    var that = this;
                    axios.get('https://autumnfish.cn/api/joke').then(
                        function (response) {
                            console.log(response.data)
                            that.joke = response.data
                        },function (err) {
                            console.log(err)
                        }
                    )
                }
            }
        })
    </script>

實(shí)例 - 天氣查詢

回車查詢

  • 按下回車(v-on .enter)
  • 查詢數(shù)據(jù)(axios 接口 v-model)
  • 渲染數(shù)據(jù)(v-for 數(shù)組 that)


    image.png
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="vue.js" type="text/javascript" charset="utf-8"></script>
    <style>
    </style>
</head>
<body>
    <div class="wrap" id="app">
        <div class="search_form">
            <div class="logo">天氣查詢</div>
            <div class="form_group">
                <input type="text" class="input_txt" placeholder="請(qǐng)輸入查詢的城市天氣" v-model="city" @keyup.enter="searchWeather">
            </div>
        </div>
        <div class="hotkey">
            <input type="button" value="北京" @click="changeCity('北京')">
            <input type="button" value="上海" @click="changeCity('上海')">
            <input type="button" value="廣州" @click="changeCity('廣州')">
            <input type="button" value="深圳" @click="changeCity('深圳')">
        </div>
        <ul class="weather_list">
            <li v-for="item in weatherList">
                <div class="info_type"><span class="iconfont">{{ item.type }}</span></div>
                <div class="info_temp">
                    <b>{{ item.low }}</b>
                    ~
                    <b>{{ item.high }}</b>
                </div>
                <div class="info_date"><span>{{ item.date }}</span></div>
            </li>
        </ul>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
    <script type="text/javascript">
        var app = new Vue({
            el: '#app',
            data: {
                city: '',
                weatherList: []
            },
            methods: {
                searchWeather: function () {
                    var that = this
                    axios.get('http://wthrcdn.etouch.cn/weather_mini?city=' + this.city).then(
                        function (response) {
                            //console.log(res.data.data.forecast)
                            that.weatherList = response.data.data.forecast
                        }
                    )//then
                },//f
                changeCity:function (city) {
                    this.city = city
                    this.searchWeather()
                }
            }//methods
        })
    </script>
</body>
</html>

這里出現(xiàn)過一個(gè)bug,就是在輸入框中輸入城市名字后,并沒有反應(yīng)
經(jīng)過排查,發(fā)現(xiàn)沒有寫v-model綁定數(shù)據(jù)
原先在輸入框后面有個(gè)button,點(diǎn)擊即可查詢天氣
但是目前還不太會(huì)寫 留個(gè)坑

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末奋献,一起剝皮案震驚了整個(gè)濱河市澎迎,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌咽笼,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件戚炫,死亡現(xiàn)場(chǎng)離奇詭異剑刑,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門施掏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钮惠,“玉大人,你說我怎么就攤上這事七芭∷赝欤” “怎么了?”我有些...
    開封第一講書人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵狸驳,是天一觀的道長(zhǎng)预明。 經(jīng)常有香客問我,道長(zhǎng)耙箍,這世上最難降的妖魔是什么撰糠? 我笑而不...
    開封第一講書人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮辩昆,結(jié)果婚禮上阅酪,老公的妹妹穿的比我還像新娘。我一直安慰自己汁针,他們只是感情好术辐,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著施无,像睡著了一般辉词。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上帆精,一...
    開封第一講書人閱讀 52,475評(píng)論 1 312
  • 那天较屿,我揣著相機(jī)與錄音,去河邊找鬼卓练。 笑死隘蝎,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的襟企。 我是一名探鬼主播嘱么,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼顽悼!你這毒婦竟也來了曼振?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤蔚龙,失蹤者是張志新(化名)和其女友劉穎冰评,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體木羹,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡甲雅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年解孙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抛人。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡弛姜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出妖枚,到底是詐尸還是另有隱情廷臼,我是刑警寧澤,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布绝页,位于F島的核電站荠商,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏续誉。R本人自食惡果不足惜结啼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望屈芜。 院中可真熱鬧,春花似錦朴译、人聲如沸井佑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽躬翁。三九已至,卻和暖如春盯拱,著一層夾襖步出監(jiān)牢的瞬間盒发,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來泰國打工狡逢, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留宁舰,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓奢浑,卻偏偏與公主長(zhǎng)得像蛮艰,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子雀彼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容