首页 > 其他分享 >12-使用Vue与axios改造jquery原页面

12-使用Vue与axios改造jquery原页面

时间:2022-11-12 19:01:13浏览次数:51  
标签:jquery function axios vue url item Vue data


改造List页面

1引入文件

<!--  1引入vuejs axios文件-->
<script type="text/javascript" src="js/vue.js"></script>
<script type="text/javascript" src="js/axios.js"></script>

2页面布局

<div  id="app">
<div v-show='viewId=="add"' id="add" style="display: none">
<h1>添加</h1>
<form id="add_form">

<br/> name:<input type="text" name="name" >
<br/> value:<input type="text" name="value" >
<br/>
<input id="add_save" type="button" value="保存" >
<input id="add_cancle" type="button" value="取消" >
</form>
</div>
<div v-show='viewId=="edit"' id="edit" style="display: none">
<h1>编辑</h1>
<form id="form_edit">
<input type="text" name="id" id="edit_form_id" hidden="hidden">
<br/> name:<input type="text" id="edit_form_name" name="name" >
<br/> value:<input type="text" id="edit_form_value" name="value" >
<br/> <input id="edit_save" type="button" value="更新" > <input id="edit_cancle" type="button" value="取消" >
</form>
</div>
<div v-show='viewId=="list"' id="list" style="display: none">
<h1>列表</h1>
<input type="button" value="添加" id="list_add">
<input type="text" value="" name="searchword">
<input type="button" value="查询">
<table border="1" width="100%">
<thead>
<tr>
<th>编号</th>
<th>姓名</th>
<th>余额</th>
<th>操作</th>
</tr>
</thead>
<tbody id="tbody">

</tbody>
</table>
</div>
</div>

3使用viewId控制视图

<script type="text/javascript">
//2:创建一个vue对象
var vue = new Vue({
el:'#app',
data:{
viewId:'list'
}
})

</script>

4使用axios获取find数据

<script type="text/javascript">
//2:创建一个vue对象
var vue = new Vue({
el:'#app',
data:{
viewId:'list',
accountList:[]
},
methods:{//定义方法
loadList:function () {
console.log("methods里面的")
console.log(this)

//向后台接口发请求获取获表
var url = "http://localhost:8002/day01/account/find"
axios.get(url).then(
function (repsonse) {
console.log("axios里面的")
console.log(this)
if(200==repsonse.data.code){
//将json数组保存到vue的data的list
//不能使用this.accountList 实际是axios.accountList
//视图要显示出来,vue需要将数据保存到data
vue.accountList = repsonse.data.data

}
// console.log(vue.accountList)
}
)
}
},
created: function () {
this.loadList()
}
})

</script>

5使用v-for显示列表

<table border="1" width="100%">
<thead>
<tr>
<th>编号</th>
<th>姓名</th>
<th>余额</th>
<th>操作</th>
</tr>
</thead>
<tbody id="tbody">

<tr v-for="(item,index) in accountList" :key="index">
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.value}}</td>
<td><a href="javascript:void(0);" >编辑</a>|<a>删除</a></td>
</tr>

</tbody>
</table>

改造删除

1 使用@click调用删除方法

<tr v-for="(item,index) in accountList"  :key="index">
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.value}}</td>
<td><a href="javascript:void(0);" >编辑</a>|<a href="javascript:void(0);" @click="deleteById(item.id)">删除</a></td>
</tr>

2在methods里面定义deleteById

deleteById:function (id) {
var url = "http://localhost:8002/day01/account/delete/"+id
axios.get(url).then(function (resp) {
if(200 == resp.data.code){
vue.loadList()
alert(data.msg)
}
})
}

改造编辑页面

添加编辑的点击事件

<tr v-for="(item,index) in accountList"  :key="index">
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.value}}</td>
<td><a href="javascript:void(0);" @click="findById(item.id)" >编辑</a>|<a href="javascript:void(0);" @click="deleteById(item.id)">删除</a></td>
</tr>

methods添加findById

findById:function (id) {
vue.viewId = 'edit'
//为界面查询数据
var url = "http://localhost:8002/day01/account/find/"+id
axios.get(url).then(function (resp) {
if(200 == resp.data.code){
vue.accountEdit = resp.data.data
}
})
},

显示在界面

<div v-show='viewId=="edit"' id="edit"  style="display: none">
<h1>编辑</h1>
<form id="form_edit">
<input type="text" name="id" id="edit_form_id" hidden="hidden" v-model:text="accountEdit.id">
<br/> name:<input type="text" id="edit_form_name" name="name" v-model:text="accountEdit.name">
<br/> value:<input type="text" id="edit_form_value" name="value" v-model:text="accountEdit.value">
<br/> <input id="edit_save" type="button" value="更新" @click="updateAccount()" > <input id="edit_cancle" type="button" value="取消" @click="loadList()" >
</form>
</div

注意看​​ v-model:text=​

在methods再添加

updateAccount:function () {
var url = "http://localhost:8002/day01/account/update"
axios.post(url,this.accountEdit).then(function(){
vue.loadList()
})
},

改造添加页面

给列表机部的添加按钮添加事件

<input type="button" value="添加" id="list_add" @click="showAdd()">

methods里面添加

showAdd:function(){
vue.viewId = 'add'
},

给更新按钮加点击事件

<div v-show='viewId=="edit"' id="edit"  style="display: none">
<h1>编辑</h1>
<form id="form_edit">
<input type="text" name="id" id="edit_form_id" hidden="hidden" v-model:text="accountEdit.id">
<br/> name:<input type="text" id="edit_form_name" name="name" v-model:text="accountEdit.name">
<br/> value:<input type="text" id="edit_form_value" name="value" v-model:text="accountEdit.value">
<br/> <input id="edit_save" type="button" value="更新" @click="updateAccount()" > <input id="edit_cancle" type="button" value="取消" @click="loadList()" >
</form>
</div>

在methods添加提交方法

addAccount:function () {

var url = "http://localhost:8002/day01/account/add"
axios.post(url,this.accountAdd).then(function(){
vue.loadList()
})
}


标签:jquery,function,axios,vue,url,item,Vue,data
From: https://blog.51cto.com/u_12937594/5846757

相关文章

  • 11-SpringBoot2整合Vue最简入门
    vuejs入门环境搭建》1:导入文件<scripttype="text/javascript"src="js/vue.js"></script><scripttype="text/javascript"src="js/axios.js"></script>》2:准备app视......
  • 如何使用vite搭建vue3项目详解
    目录一:npm构建二:更改http://localhost:3000/到8080与Network路由访问三:配置vite别名(npminstall@types/node--save-dev)四:路由(npminstallvue-router@4)五:vuex(n......
  • vue 翻页组件vue-flip-page
    方法change(改变页面)tap(点击)turning(正在翻页)prev(前一页)next(后一页)翻到指定页面:handleSwitchManual(index){if(index===this.currentIndex)......
  • Vue中JSX的基本用法
    基本用法首先需要约定一下,使用JSX组件命名采用首字母大写的驼峰命名方式,样式可以少的可以直接基于vue-styled-components写在同一个文件中,复杂的建议放在单独的_Styles.js_......
  • SpringBoot+Vue实现excel导入带格式化的时间参数(moment格式化明天日期并设置el-date-
    场景若依管理系统前后端分离版基于ElementUI和SpringBoot怎样实现Excel导入和导出:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/108278834在上面进行Ex......
  • 使用vue 搭建猫眼后台演员列表
    首先创建一个DirectorList.vue js部分 ......
  • Vue项目实现用户长时间不操作,自动退出登录
    Vue项目实现用户长时间不操作,自动退出登录1.实现思路使用mouseover事件来监测是否有用户操作页面,然后写一个定时器间隔特定时间检测是否长时间未操作页面,如果是清除tok......
  • 16. VUE怎么阻止冒泡
    给事件添加stop修饰符,比如click.stop ;补充:阻止默认行为prevent修饰符,超链接的跳转,表单的默认提交;once修饰符事件只触发一次ps:事件修饰符可以连着......
  • 14. Vue2 和 Vue3 区别
    主要分为四点:1.Vue3使用了proxy替代了Object.defineProperty实现响应式数据,所以vue3的性能得到了提升;2.Vue3可以在template模板使用多个根标......
  • 13. 说一下$set,用在Vue2还是Vue3
    $set是vue2中对象用来追加响应式数据的方法;使用格式:$set(对象,属性名,值) vue3中使用proxy替代了Object.defineProperty实现对象的响应式数据,所以在......