父組件有個(gè)input文本框 子組件也是很多input框 這是效果圖:
嗯想實(shí)現(xiàn)的功能是:
我再父文本框里輸入: ?get=1&name=2&name=3能自動(dòng)在子組件里生成數(shù)據(jù)
在子文本框里輸入 數(shù)據(jù)能自動(dòng)填充到父文本框里
下面代碼是簡(jiǎn)化版本:
父組件
<template>
<input type="text" v-model = "requestUrl">
<component :is = "view" :requestUrl = "requestUrl" @queryString = "queryString"></component>
</template>
<script>
//利用動(dòng)態(tài)組件實(shí)現(xiàn)選項(xiàng)卡切換
import formView from './form';
import queryView from './query';
import jsonView from './json';
export default {
components: {
formView,
jsonView,
queryView,
},
data()
{
return {
view: "formView", //默認(rèn)組件
viewIndex:0, //組件索引
requestUrl: "", //接口地址
//選項(xiàng)卡
tab: [{
"name": "Form",
"view": "formView",
//表示form下面的二級(jí)選項(xiàng)卡
"options": [{
"name": "Form",
"view": "formView"
},{
"name": "JSON",
"view": "jsonView",
}, {
"name": "XML",
"view": "xmlView"
}]
}, {
"name": "Query",
"view": "queryView",
}],
}
},
methods: {
//接受query子組件拋出的事件
queryString(data)
{
var params = '?';
for(var i = 0; i < data.length; i++) {
if($.trim(data[i].value)) {
params += data[i].key + '=' + data[i].value + '&';
} else {
params += data[i].key + '&';
}
}
this.requestUrl = this.requestUrl.replace(/\?.+/, '') + params
}
}
}
</script>
query子組件:
<template>
<div class = "query">
<table v-if="data">
<tr v-for = "val,index in data">
<td>
<input :checked="val.is" type = "checkbox">
</td>
<td>
<input v-model = "val.key"></input>
</td>
<td>
<input v-model = "val.value"></input>
</td>
</tr>
</table>
</div>
</template>
<script>
export default {
props:["requestUrl"],
data()
{
return {
data:[],
}
},
watch: {
requestUrl()
{
var url = this.requestUrl.split('?');
var data = [];
if(url.length > 1) {
url = url[1].split('&');
for(var i = 0; i < url.length; i++) {
// var data =
var u = url[i].split('=');
if(u[1] == undefined) {
u[1] = '';
}
data.push({
"is": 1,
"key": u[0],
"value": u[1]
});
}
}
this.data = data;
}
},
updated()
{
//計(jì)算data數(shù)據(jù)變化, 收集key不為空且is=1的數(shù)據(jù) 傳遞給父組件
var data = [];
for(var i = 0; i < this.data.length; i++) {
if($.trim(this.data[i].key) && this.data[i].is) {
data.push(this.data[i]);
}
}
this.$emit('queryString', data);
},
}
</script>
我說下我的邏輯(看對(duì)不對(duì))
1、因?yàn)轫撁嬗泻芏噙x項(xiàng)卡 我采用的是動(dòng)態(tài)組件方式加載的選項(xiàng)卡 每個(gè)子組件的data都是子組件自己處理的并不是父組件傳過來的。我再子組件內(nèi)部監(jiān)聽數(shù)據(jù)變化updated過濾一些數(shù)據(jù)后$emit給父組件的querySting方法,父組件的queryStirng方法接受到之后處理一些邏輯 修改requestUrl (實(shí)現(xiàn)了子組件的input發(fā)生變化父組件的input框也跟著發(fā)生變化)
2、query子組件接受父組件傳過來的requestUrl值 然后在子組件內(nèi)部watch監(jiān)聽requestUrl變化進(jìn)行修改data(實(shí)現(xiàn)父組件url框發(fā)生變化 子組件內(nèi)部的data也跟著變化。)
很辛運(yùn)的是這樣并沒有發(fā)生死循環(huán)
碰到的問題是: 我在父組件url框進(jìn)行編輯的時(shí)候
=號(hào)以及&號(hào)沒辦法輸入 最終都會(huì)被queryString方法重新處理一遍
{
var params = '?';
for(var i = 0; i < data.length; i++) {
if($.trim(data[i].value)) {
params += data[i].key + '=' + data[i].value + '&';
} else {
params += data[i].key + '&';
}
}
this.requestUrl = this.requestUrl.replace(/\?.+/, '') + params
}
我不太清楚vue還有沒有更好的一種方式實(shí)現(xiàn)。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問,美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。