纯vue以及vue+laravel父组件往子组件传递图片路径

简介: 纯vue以及vue+laravel父组件往子组件传递图片路径

     

Demo1 仅仅是在vue中

动态绑定的图片文件应该放在static下,地址写法是

imageUrl = '/static/image.png'

动态绑定的图片写法是

<img v-bind:src="imgUrl"/>

实例:

Home.vue 父组件
<template>
  <div class="homeClass">
      <HomeCard v-for="i in msg" :msg="i" ></HomeCard>
  </div>
</template>
<!-- 主页 -->
<script>
import HomeCard from "@/components/HomeCard.vue"
export default {
  components:{
    HomeCard,
  },
  data () {
    return {
      msg: [
              {
                    title:"title1",
                    intro:'intro1',
                    photoAdress:"/static/intro1.jpg"
              },
              {
                    title:"title2",
                    intro:'intro2',
                    photoAdress:"/static/intro2.jpg"
              },
              {
                    title:"title3",
                    intro:'intro3',
                    photoAdress:"/static/intro3.jpg"
              }
      ]
    }
  },
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.homeClass{
  padding-left: 130px;
}
</style>

homecard.vue 子组件

<template>
            <el-card class="box-card">
                <h2>
                    {{msg.title}}
                </h2>
                <span>
        {{msg.intro}}
      </span>
                <img v-bind:src="msg.photoAdress" alt="photo">
            </el-card>
</template>
<script>
    export default {
        name: "HomeCard",
        data() {
            return {};
        },
        props: ['msg']
    }
</script>
<style scoped>
    .box-card {
        width: 360px;
        float: left;
        margin: 0 33px 0px 0;
    }
    img {
        width: 310px;
        height: 280px;
        padding-top: 20px;
        padding-right: 30px;
    }
</style>

Demo2 laravel+vue

使用require() (此方法同样适用于纯vue)

####在resources\assets\js创建staic文件,用于存放图片

实例

Home.vue

<template>
    <div class="homeClass">
        <HomeCard v-for="msg in msgs" :msg="msg"></HomeCard>
    </div>
</template>
<!-- 主页 -->
<script>
    import HomeCard from "./../components/HomeCard.vue"
    export default {
        components: {
            HomeCard,
        },
        data() {
            return {
                msgs: [
                    {
                        title: "title1",
                        intro: 'intro1',
                        photoAdress: require("./../static/intro1.jpg") ,
                    },
                    {
                        title: "title2",
                        intro: 'intro2',
                        photoAdress: require("./../static/intro2.jpg") ,
                    },
                    {
                        title: "title3",
                        intro: 'intro3',
                        photoAdress: require("./../static/intro3.jpg") ,
                    }
                ]
            }
        },
    }
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
    .homeClass {
        padding-left: 130px;
    }
</style>

HomeCard.vue

<template>
    <el-card class="box-card">
        <h2>
            {{msg.title}}
        </h2>
        <span>
        {{msg.intro}}
      </span>
        <img  v-bind:src="msg.photoAdress" alt="photo">
    </el-card>
</template>
<script>
    export default {
        name: "HomeCard",
        data() {
            return {};
        },
        props: ['msg']
    }
</script>
<style scoped>
    .box-card {
        width: 360px;
        float: left;
        margin: 0 33px 0px 0;
    }
    img {
        width: 310px;
        height: 280px;
        padding-top: 20px;
        padding-right: 30px;
    }
</style>


相关文章
|
3月前
|
JavaScript API
vue使用hook:声明周期来监听子组件的声明周期
本文介绍了如何在Vue中使用生命周期钩子来监听子组件的生命周期事件,包括在子组件内部监听和在父组件中监听子组件的生命周期钩子。
57 0
|
2月前
|
JavaScript
Vue 的父组件和子组件生命周期钩子执行顺序
在 Vue 中,父组件和子组件的生命周期钩子执行顺序如下:
|
2月前
|
监控 JavaScript 开发者
在 Vue 中,子组件为何不可以修改父组件传递的 Prop,如果修改了,Vue 是如何监控到属性的修改并给出警告的
在 Vue 中,子组件不能直接修改父组件传递的 Prop,以确保数据流的单向性和可预测性。如果子组件尝试修改 Prop,Vue 会通过响应式系统检测到这一变化,并在控制台发出警告,提示开发者避免这种操作。
|
2月前
|
存储 JavaScript 前端开发
vue尚品汇商城项目-day05【30.登录与注册静态组件(处理公共图片资源问题)+31.注册的业务+登录业务】
vue尚品汇商城项目-day05【30.登录与注册静态组件(处理公共图片资源问题)+31.注册的业务+登录业务】
37 1
|
2月前
|
JavaScript
Vue启动时报错的解决方案,以及解决相同路径跳转报错的问题
Vue启动时报错的解决方案,以及解决相同路径跳转报错的问题
379 0
|
3月前
|
JavaScript
Vue在子组件中判断父组件是否传来事件
本文介绍了在Vue中如何通过`vm.$listeners`对象来判断父组件是否传递了特定的事件给子组件,并展示了如何检查事件是否存在以及相应的处理方法。
236 0
Vue在子组件中判断父组件是否传来事件
|
2月前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-48.(了解)图片懒加载插件】
vue尚品汇商城项目-day07【vue插件-48.(了解)图片懒加载插件】
38 0
|
1月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
7天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
1月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
41 1
vue学习第一章

热门文章

最新文章