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


相关文章
|
6天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
7天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
6天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
6天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
20天前
|
数据采集 监控 JavaScript
在 Vue 项目中使用预渲染技术
【10月更文挑战第23天】在 Vue 项目中使用预渲染技术是提升 SEO 效果的有效途径之一。通过选择合适的预渲染工具,正确配置和运行预渲染操作,结合其他 SEO 策略,可以实现更好的搜索引擎优化效果。同时,需要不断地监控和优化预渲染效果,以适应不断变化的搜索引擎环境和用户需求。
|
7天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
7天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
8天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
8天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
13天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发