A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

一、vue的组件化应用
  首先,知道有哪些相关的属性需要用到,再慢慢去理解,运用。
  1.两个vue页面  2. slot占位符(可用可不用)  3.props内置属性  4.watch监听函数  5.import导入vue的功能  6.data的return里需要返回值需要放进去,如 data: ' ' 就行了
  第一步,写好两个vue页面,我这里写的是dialog(对话框)的弹框运用
(1)子组件(dialog)基本代码如下

[url=][/url]
<template>  <el-dialog title="编辑规格" :visible.sync="sizeedit" @close="closingedit" width="30%">

  <el-form :model="form" ref="form" label-width="80px" :rules="rules">      <el-form-item label="规格名称" prop="name">
        <el-input v-model="form.name" autocomplete="off"></el-input>
      </el-form-item>
    </el-form>   <div slot="footer" class="dialog-footer">      <el-button type="warning" size="small" @click="reset('form')">重置</el-button>
      <el-button type="danger" size="small" @click="close">取消</el-button>
      <el-button type="primary" size="small" @click="save('form')">保存</el-button>
   </div>
 </el-dialog>
</template>[url=][/url]

data里
form: {}

sizeedit: false,
methods里
[url=][/url]
  close () {      this.$emit('close-sizeedit', true)    },    reset () {      this.$refs.form.resetFields()    },    closingedit () {      this.$emit('close-sizeedit', true)    },[url=][/url]

(2)父组件中
需要传递的值为id,通过函数传递id
handleEdit (id) {      console.log(id)      this.editId = id      this.sizeeditVisible = true      console.log(this.sizeeditVisible)    },
所以交流的值是editId
(3)两个页面基本完成的情况下,第一步,导入子组件,并且绑定传递的参数
import sizeedit from './sizeedit'
components: {    sizeedit  }
<sizeedit :sizeedit-visible="sizeeditVisible" @close-sizeedit="sizeeditVisible = false" :edit-id="editId"/>
父组件,data里
editId: '',sizeeditVisible: false,
子组件,要开始添加内置属性props和watch监听参数的变化,然后执行函数
[url=][/url]
props: {    'sizeeditVisible': Boolean,    'editId': String  }watch: {    sizeeditVisible () {      this.sizeedit = this.sizeeditVisible      this.showEdit()    }  }
[url=][/url]

methods里
[url=][/url]
showEdit () {      console.log(this.editId)      let formData = new FormData()      formData.append('id', this.editId)      let config = {headers: {'Content-Type': 'multipart/form-data'}}      this.$http.post('/psi/base/edit', formData, config).then(res => {        console.log(this.form)        this.form.name = res.data.data.name      })    }[url=][/url]

那么,基本只要父组件的id是确实在变化而且不是undefined【一般都是输入框变化的值】(判断方法,在相应函数下,console.log(id)),那么form里的规格名称就会改变。
组件套用,参数(String,Boolean)传递基本完成。
二、小问题总结
需要注意的几个小问题
1.关于form的-1 this.$refs.form.resetFields()  是清空form数据的函数,但是前提,你的form属性不能少,form-item里props一定要有-2 一定要有v-model属性,如文中的v-model = "form.name"-3 在data里的数据,form需要帮name占位,这样子,你传递的值才会放进来form: { name: '' }            
2.关于子父组件的-1 绑定数据时,一定要注意,父组件里需要定义editId,在data设置为空就行(注意在父组件用console.log检测是否id有值)-2 子组件里,要有props和watch,用来监听你的值发生变化,从而相应做出动作-3 在父组件引用子组件时,要记得用import导入,而且在components组件里,导入那个标签,从而才能在父组件的vue页面里放子组件的大标签-4 注意传递的数据,在引用子组件标签时,绑定editId3.关于敲代码找错的-1 遇到问题,看控制台,点击右键,检查,然后在console里看是什么错-2 如果console里没有报红,而又确实没有数据,那你就要考虑是函数功能并没有被调用,还是你没有把数据放进去,导致调用了也是空值-3 学会找到出错的地方,比如你想实现那个功能,但是点击发现并没有发生函数功能,那么你就需要检查函数,以及相关的绑定值,多打打console.log,看是否都有值。暂时这篇文章涉及到的就是String和Boolean类型的传值,晚点看下下次有没有空,再添加一下form的传递,就是Object,会比较蛋疼,但是和这里的写法是不一样的。
【转载,仅作分享,侵删】
原文地址:https://www.cnblogs.com/qq946487 ... 03/15/10535700.html

1 个回复

倒序浏览
奈斯,感谢分享
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马