vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > vue前端获取django后端数据

vue前端获取django后端数据实现方式

作者:Wanncye

这篇文章主要介绍了如何在Vue组件中使用axios获取和处理数据,并在模板中展示这些数据,文章还详细讲解了Vue的生命周期、v-for指令的使用以及axios与ajax的区别

script

首先我们在想要获得数据的vue组件里的script部分编写获取数据、处理数据的方法,然后将数据返回。返回的数据可以在template部分获取、展示。

<script>
    export default {
        name: "Banner",
        data(){
          return{
            banner_list : []
          }
        },
        created(){
          this.get_banner_list();
        },
        methods: {
          get_banner_list(){
            //获取轮播广告
            this.$axios.get(`${this.$settings.HOST}/banner`, {}).then(response=>{
            console.log(response.data)
            this.banner_list = response.data
            }).catch(error=>{
              console.log(error.response)
            })
          }
        }
    }
</script>

因为前面我们已经在main.js中将axios、setting作为vue的property,所以我们能够直接通过this来调用。

这里有几个点需要注意:

  1. ${}语法:{}中,javascript会将其认为是变量,在渲染的时候会填充相应的值
  2. axios使用方法得记住
  3. created(){}是vue的生命周期,有必要了解,起码得熟悉

template

<template>
  <el-carousel height="720px" :interval="3000" arrow="always">
    <el-carousel-item :key="key" v-for="banner,key in banner_list">
      <a :href="banner.link" rel="external nofollow" >
        <img :src="banner.image_url">
      </a>
    </el-carousel-item>
  </el-carousel>
</template>

在标签中循环script返回的列表,将得到的image_url作为img标签的源链接,得到的link作为a标签的跳转链接。

有这么几个点要注意:

  1. v-for的使用,有点像python里面的for循环
  2. vue的属性前的冒号

加冒号的,说明后面的是一个变量或者表达式;

没加冒号的后面就是对应的字符串字面量。

ajax和axios有什么区别呢?

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文