vue中input输入框触发功能父子组件传值

本文探讨了在Vue.js中如何通过input事件实现父子组件间的通信,特别是在子组件中更新输入框值时如何将变化传递给父组件的例子。

子组件: 

<template>
  <div class="inputTip">
    <el-input v-model="currentValue" @input="childClick"></el-input>
    <el-tooltip class="item" effect="dark" :content="msg" placement="top">
      <i class="el-icon-warning-outline"></i>
    </el-tooltip>
  </div>
</template>

<script>
export default {
  name: 'inputTip',
  props: {
    msg: String
  },
  data () {
    return {
      currentValue: ''
    }
  },
  methods: {
    childClick () {
      this.$emit('inputHandle', this.currentValue)
    }
  }
}
</script>

父组件:

<template>
  <div class="userAdd">
    <el-form>
      <el-form-item label="活动名称">
        <input-tip :msg="msg" @inputHandle="inputHandle"></input-tip>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
import InputTip from '../../../components/inputTip'
export default {
  name: 'userAdd',
  components: {InputTip},
  data () {
    return {
      msg: '提示信息',
      selectVal: ''
    }
  },
  methods: {
    inputHandle (val) {
      this.selectVal = val
    }
  }
}
</script>

自己编辑

子组件:

<template>
	<view>
		<view class="content_box">
			<view class="explain_box">
				<view class="blue_icon"></view>
				<view class="explain_text">
					{{title}} 
					<span style="color:#FF0C5C;margin:10rpx;">*</span>
				</view>
				<view class="input_box">
					<textarea v-model="changeValue"
						 @input="descInput" placeholder-class="phClass"
						 :placeholder=placeholder
						 class="uni-input" maxlength="200">
					</textarea>
					<span class="numberv">{{txtVal}}/200</span>
				</view>
			</view>
		</view>
	</view>
</template>

<script>
	export default {
		props: {
			/**
			 * 标题
			 */
			title: {
				default: '变更说明',
				type: String
			},
			/**
			 * 占位说明
			 */
			placeholder: {
				default: '请输入',
				type: String
			}
		},
		components:{},
		data() {
			return {
			  changeValue:'',	
			  txtVal: 0,
			};
		},
		methods:{
			descInput(){
				this.txtVal = this.changeValue.length
				this.$emit('inputHandle', this.changeValue)
			},
		}
	}
</script>

<style  lang="less" scoped>
	.content_box{
		width: 690rpx;
		background-color: #fff;
		margin: 24rpx auto 0 auto;
		border-radius: 20rpx;
		.explain_box{
			padding: 35rpx 30rpx  61rpx 30rpx;
			.blue_icon{
				width: 8rpx;
				height: 28rpx;
				background: #027AFF;
				border-radius: 4px;
			}
			.explain_text{
				font-size: 30rpx;
				font-weight: bold;
				color: #333333;
				margin: -33rpx 0 0 20rpx;
				
			}
		}
		.uni-input{
			// border: 1px solid red;
			width: 582rpx;
			height: 160rpx;
		}
		.phClass{
			color: #E3E3E3;
			font-size: 26rpx;
		}
		.input_box{
			border: 1px solid #E3E3E3;
			width: 582rpx;
			height: 200rpx;
			position: relative;
			margin-top: 36rpx;
			padding: 25rpx 24rpx 0 24rpx;
			.numberv{
				position: absolute;
				right: 0;
				bottom: 0;
			}
		}
	}
</style>

父组件 

		<input-textarea title="变更说明" placeholder='请输入变更说明' @inputHandle="inputHandle"></input-textarea>

methods:{
			inputHandle(val){
				this.changeValue=val
			},
		}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq614756883

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值