Nuxt.js 数据双向绑定的实现


Posted in Javascript onFebruary 17, 2019

假定我们有一个需求,一开始通过mounted()将一个字符串渲染在页面上,但是我们经过操作后修改了数据并且需要将得到的结果重新异步渲染到页面中去,而不是跳转刷新页面来重新渲染

首先模板中data()中定义数据,并且要将定义的数据显示出来

<template>
  <div>
    <span @click="click">{{ text }}</span>
  </div>
</template>

<script>
  export default {
   data(){
    return {
     text: '',
     newText: '1'
    }
   },
   async mounted(){
     let {status,data:{text}} = await self.$axios.post('/getText');
     this.text = text;
   }
  }
</script>

然后我们通过methods里的函数来获取后台的数据

methods:{
  async click(){
    let {status,data:{text}} = await self.$axios.post('/updateText',{
      text,
      newText
    })
   
    this.text = text;
  }
  
}

服务端的接口如下

router.get('/getText', async (ctx) => {
  let text= await Text.find();
  ctx.body = {
    text
  }
}

router.post('/updateText', async (ctx) => {
 const {text,newText} = ctx.request.body;
 let oldVal = text;
 let newVal = newText;

 let ncomment = await Comment.updateOne(oldVal,newVal);

 let text= await Text.find();

 ctx.body={
  text
 }
})

这里有个重点!

获取页面传过来的参数时必须使用结构赋值的方法获取,不然获取到的为一个Object,查询将会出错!

双向绑定在这里的体现是:一开始通过mounted()将数据渲染到模板中,然后调用函数通过服务端的updateText接口改变数据,在updateText接口中更新完数据后,执行一遍查询,将查询结果返回到触发的函数中。并在该函数中修改data()中text的值达到数据双向绑定的效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery实现邮箱自动补全功能示例分享
Feb 17 Javascript
jQuery实现的原图对比窗帘效果
Jun 15 Javascript
探寻Javascript执行效率问题
Nov 12 Javascript
javascript中的this详解
Dec 08 Javascript
javascript判断变量是否有值的方法
Apr 20 Javascript
JavaScript让Textarea支持tab按键的方法
Jun 26 Javascript
jQuery绑定事件-多种实现方式总结
May 09 Javascript
微信小程序 rpx 尺寸单位详细介绍
Oct 13 Javascript
angularjs中回车键触发某一事件的方法
Apr 24 Javascript
jQuery实现鼠标响应式淘宝动画效果示例
Feb 13 jQuery
Vue数字输入框组件的使用方法
Oct 19 Javascript
如何利用Node.js与JSON搭建简单的动态服务器
Jun 16 Javascript
详解微信小程序实现仿微信聊天界面(各种细节处理)
Feb 17 #Javascript
JavaScript遍历DOM元素的常见方式示例
Feb 16 #Javascript
原生JS实现逼真的图片3D旋转效果详解
Feb 16 #Javascript
JS实现简单的抽奖转盘效果示例
Feb 16 #Javascript
mocha的时序规则讲解
Feb 16 #Javascript
jQuery实现ajax的嵌套请求案例分析
Feb 16 #jQuery
解决微信小程序中转换时间格式IOS不兼容的问题
Feb 15 #Javascript
You might like
两个强悍的php 图像处理类1
2009/06/15 PHP
PHPExcel读取Excel文件的实现代码
2011/12/06 PHP
PHP屏蔽蜘蛛访问代码及常用搜索引擎的HTTP_USER_AGENT
2013/03/06 PHP
thinkphp中AJAX返回ajaxReturn()方法分析
2016/12/06 PHP
Jquery实现无刷新DropDownList联动实现代码
2010/03/08 Javascript
javascript学习笔记(六) Date 日期类型
2012/06/19 Javascript
js截取固定长度的中英文字符的简单实例
2013/11/22 Javascript
js获取时间(本周、本季度、本月..)
2013/11/22 Javascript
javascript数字时钟示例分享
2014/04/23 Javascript
html5+javascript制作简易画板附图
2014/04/25 Javascript
解决Jquery向页面append新元素之后事件的绑定问题
2015/03/16 Javascript
JavaScript进阶练习及简单实例分析
2016/06/03 Javascript
AngularJs ng-route路由详解及实例代码
2016/09/14 Javascript
jquery把int类型转换成字符串类型的方法
2016/10/07 Javascript
vue实现app页面切换动画效果实例
2017/05/23 Javascript
vue服务端渲染的实例代码
2017/08/28 Javascript
代码详解JS操作剪贴板
2018/02/11 Javascript
vue和webpack打包项目相对路径修改的方法
2018/06/15 Javascript
AngularJS 多指令Scope问题的解决
2018/10/25 Javascript
[04:59]DOTA2-DPC中国联赛 正赛 Ehome vs iG 选手采访
2021/03/11 DOTA
Python全局变量与局部变量区别及用法分析
2018/09/03 Python
对Python3 pyc 文件的使用详解
2019/02/16 Python
python 对象真假值的实例(哪些视为False)
2020/12/11 Python
Pytorch模型迁移和迁移学习,导入部分模型参数的操作
2021/03/03 Python
HTML5全屏(Fullscreen)API详细介绍
2015/04/24 HTML / CSS
Corelle官方网站:购买康宁餐具
2016/11/02 全球购物
测绘工程个人的自我评价
2013/11/23 职场文书
初中同学聚会感言
2014/02/11 职场文书
单位员工收入证明样本
2014/10/09 职场文书
企业三严三实学习心得体会
2014/10/13 职场文书
民事和解协议书格式
2014/11/29 职场文书
公证处委托书
2015/01/28 职场文书
心灵捕手观后感
2015/06/02 职场文书
2016年端午节红领巾广播稿
2015/12/18 职场文书
python 调用js的四种方式
2021/04/11 Python
flex弹性布局详解
2022/03/20 HTML / CSS