Vue 기반 도서 관리 기능 구현
<table class="table table-bg table-border table-bordered">
<tr>
<th>ID</th>
<th> </th>
<th> </th>
<th> </th>
<th> </th>
</tr>
<tr v-for="(book,index) in books">
<td>{{book.id}}</td>
<td>{{book.name}}</td>
<td>{{book.author}}</td>
<td>{{book.price}}</td>
<td>
<button class="btn" @click="delBook(index)"> </button>
</td>
</tr>
</table>
<fieldset>
<legend> </legend>
<p> :<input type="text" v-model="newBook.name"></p>
<p> :<input type="text" v-model="newBook.author"></p>
<p> :<input type="text" v-model="newBook.price"></p>
<p><button class="btn" @click="addBook"> </button></p>
</fieldset>
<script>
new Vue({
el:'#books',
data:{
books:[
{id:1, name:' ', author:' ', price:'1'},
{id:2, name:' ', author:' ', price:'2'},
{id:3, name:' ', author:' ', price:'3'}
],
newBook:{
id:0,
name:'',
author:'',
price:''
}
},
methods:{
delBook:function(idx){
if(window.confirm(' ?')){
this.books.splice(idx, 1);
}
},
addBook:function(){
//
if(this.newBook.name.length == 0) {
alert(' ');
return;
}
if(this.newBook.author.length == 0){
alert(' ');
return;
}
if(this.newBook.price.length == 0){
this.newBook.price = '0'
}
// id
var maxId = 0;
for(var i=0; i<this.books.length; i++){
if(maxId<this.books[i].id){
maxId = this.books[i].id;
}
}
this.newBook.id = maxId+1;
// books
this.books.push(this.newBook);
//
this.newBook = {};
}
}
});
</script>
효과 그림:이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Vue Render 함수로 DOM 노드 코드 인스턴스 만들기render에서createElement 함수를 사용하여 DOM 노드를 만드는 것은 직관적이지 않지만 일부 독립 구성 요소의 디자인에서 특수한 수요를 충족시킬 수 있습니다.간단한 렌더링 예는 다음과 같습니다. 또한 v...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.