纯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>


相关文章
|
8月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
726 2
|
7月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
612 137
|
10月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
728 1
|
10月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
517 0
|
JavaScript 前端开发
vue中在父组件点击按钮触发子组件的事件
vue中在父组件点击按钮触发子组件的事件
vue中在父组件点击按钮触发子组件的事件
|
11月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
1158 0
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
1438 4
|
11月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
12月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1670 78
|
缓存 JavaScript 前端开发
Vue 基础语法介绍
Vue 基础语法介绍