Vue js - Tambahkan teks dan kotak lungsur turun ke kotak kandungan HTML yang boleh diedit
P粉288069045
2023-07-27 17:02:54
<p>Saya menggunakan Vue.js. Saya cuba menambah teks dan kotak lungsur turun dalam div HTML yang boleh diedit. </p><p>Saya mahu menambah kotak lungsur turun menggunakan butang. Kotak lungsur ini boleh ditambah di mana-mana dalam teks, sama seperti tempat saya meletakkan kursor saya. </p><p>Sekarang, ia hampir berfungsi, tetapi saya tidak menemui masalah. </p><p>Apabila saya memasukkan dan menambah berbilang kotak lungsur dan kemudian menekan butang "Dapatkan Model Data", ia sentiasa menunjukkan bahawa pilihan kotak lungsur yang saya pilih adalah salah. Maksud saya ia sentiasa menunjukkan pilihan pertama. </p><p>Menggunakan butang "Dapatkan Model Data" ini, saya cuba mendapatkan semua pilihan teks+pilihan. </p><p>Berikut ialah kod saya:</p><p><br /></p>
<pre class="brush:php;toolbar:false;"><template>
<div>
<div class="content-editable" contenteditable="true" @input="onInput" ref="contentEditable"></div>
<butang @click="addDropdown">Tambah Dropdown</button>
<button @click="getDataModel">Dapatkan Model Data</button>
<div>{{ dataModel }}</div>
</div>
</template>
<skrip>
eksport lalai {
data() {
kembali {
kandungan: '',
lungsur turun: [],
Pilihan jatuh turun: ['Pilihan 1', 'Pilihan 2', 'Pilihan 3'],
Model data: '',
};
},
kaedah: {
onInput(event) {
this.content = event.target.innerHTML.replace(/<div><br></div>/g, '');
},
addDropdown() {
const dropdown = {
selectedOption: this.dropdownOptions[0],
};
this.dropdowns.push(dropdown);
const editableDiv = this.$refs.contentEditable;
const dropdownSelect = document.createElement('select');
dropdownSelect.style.width = '100px';
this.dropdownOptions.forEach((option) => {
const dropdownOption = document.createElement('option');
dropdownOption.value = pilihan;
dropdownOption.text = pilihan;
dropdownSelect.appendChild(dropdownOption);
});
editableDiv.appendChild(dropdownSelect);
},
getDataModel() {
const editableDiv = this.$refs.contentEditable;
const clonedDiv = editableDiv.cloneNode(true);
const selectElements = clonedDiv.querySelectorAll('select');
this.dropdowns.forEach((dropdown, index) => {
const selectedOption = dropdown.selectedOption;
const selectedOptionText = Array.from(selectElements[index].options).find((option) => option.value === selectedOption)?.text;
const selectedOptionTextNode = document.createTextNode(` ${selectedOptionText}`);
selectElements[index].replaceWith(selectedOptionTextNode);
});
this.dataModel = clonedDiv.textContent;
},
},
};
</skrip>
<skop gaya>
.content-editable {
sempadan: 1px pepejal #ccc;
padding: 10px;
ketinggian min: 100px;
margin-bawah: 10px;
}
</style></pre>
<p><br /></p>
Vue.js dipacu data dan mengamalkan pemikiran MVVM. Jika anda ingin membuat berbilang teg "input", lebih masuk akal untuk menggunakan v-for dan bukannya mencipta DOM secara dinamik.
Semoga ini membantu!