当前位置: 首页 > news >正文

做网站挣钱快吗沈阳网站建设的价格

做网站挣钱快吗,沈阳网站建设的价格,服装设计公司名称大全,app手机软件在前端开发学习中,用JavaScript脚本写个数字时钟是很常见的案例,也没什么难度。今天有时间,于是就用Vue的方式来实现这个功能。原本以为是件非常容易的事,没想到却卡在两个问题上,一个问题通过别人的博文已经找到答案&…

在前端开发学习中,用JavaScript脚本写个数字时钟是很常见的案例,也没什么难度。今天有时间,于是就用Vue的方式来实现这个功能。原本以为是件非常容易的事,没想到却卡在两个问题上,一个问题通过别人的博文已经找到答案,还有一个问题却还是不知道是什么原因造成的。

问题一 this指向的问题

mounted() {var _this = this;setInterval(function () {_this.today = new Date()}, 1000)
}

在上面这段代码中,我开始不太理解为什么要把 _this = this,感觉有点多此一举。于是便把这行代码弃了,直接用this,结果程序不能正常执行了。我知道是this的原因,但是个中具体的缘由却说不明白。
后来在网上看到一篇博文,把这个问题三言两语就说明白了,非常感谢博主的分享。
我们要获取vue变量或方法的时候,一般使用this,但是在回调函数中,this指向的就不是vue变量,而是回调函数本身,所以在一开始的时候,先定义_this=this,这样在任何位置都可以用_this来获取vue变量或方法。
也就是说,回调函数外的this指的是Vue对象,回调函数内的this默认是指向回调函数了,两者不相同,这样_this = this就不难理解了。

问题2 格式化时、分、秒的时候,用了三目运算符,分成两行写,程序可以正常运行,合成一行写就是undefined。

(1)分成两行写,正常运行,代码如下,效果如图。

 var second = this.today.getSeconds() second = second < 10 ? '0' + second : second

在这里插入图片描述
(2)合成一行写,显示undefined,代码如下,效果如下图。

var second = this.today.getSeconds() < 10 ? '0' + second : second

在这里插入图片描述

试了一下,在javaScript中也是这样的,我不清楚是什么原因造成的,是我的代码有错误吗?或者三目运算符有什么要求?

补充:

昨天在三目运算符这里,测试了半天没有找到原因,今天又试了试,发现之前的写法果然是错误的,显示“undefined”的原因终于找到了。正确的写法如下:

    var second =(second = this.today.getSeconds()) < 10 ? '0' + second : second

括号内是先声明变量并赋值,(second = this.today.getSeconds()),赋值运算符优先级较低,需要加括号。

用一行写结构比较复杂,还不好理解,不如分成两行写呢。
完整代码如下:

<!DOCTYPE html>
<html>
<head><title>实时显示的日期和时间</title><script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head><body><div id="app">{{message}}<sub-component v-if="show"></sub-component><button @click="change">切换</button></div><template id="displayTime"><div>{{dispTime() }}</div></template>
</body>
<script type="text/javascript">const SubComponent = {template:'#displayTime',data() {return {today: new Date(),}},methods: {dispTime() {var year = this.today.getFullYear()var month = this.today.getMonth() + 1var date = this.today.getDate()var hour = this.today.getHours()hour = hour < 10 ? '0' + hour : hourvar minute = this.today.getMinutes();minute = minute < 10 ? '0' + minute : minute// var second = this.today.getSeconds() // second = second < 10 ? '0' + second : secondvar second = this.today.getSeconds() < 10 ? '0' + second : secondreturn `${year}${month}${date}${hour}:${minute}:${second}`}},mounted() {var _this = this;var timer = setInterval(function () {_this.today = new Date()}, 1000)},//实例销毁之前调用beforeUnmount() {if (this.timer) {clearInterval(this.timer); //在Vue实例销毁前清除定时器}console.log('清除时钟')}}const RootComponent={data() {return {message: '数字时钟',show: true,}},methods: {change() {this.show = !this.show}},components:{SubComponent,}}const vueApp = Vue.createApp(RootComponent)vueApp.mount("#app")
</script>
</html>
http://www.yayakq.cn/news/390235/

相关文章:

  • 哈尔滨网站备案手续wordpress 微信 分享
  • 金阳龙泉苑网站建设长沙3合1网站建设电话
  • 西海岸建设局网站网页设计与制作成品是啥样的
  • 网站seo是干什么的上海免费网站建设公司
  • 单页网站订单系统怎么改邮箱企业网站 建设公司
  • 思途旅游cms网站建设系统wordpress plugins.php
  • wordpress建小说站收费python前端开发
  • 硅胶模具技术支持东莞网站建设苏州网站建设外贸
  • 微信做模板下载网站有哪些外贸公司出口退税申报流程
  • 动态asp.net网站开发教程企业网站cms模板
  • 哈尔滨网站公司良精网站管理系统
  • 国外免费建站网站搭建做网站用百度百科的资料会侵权吗
  • 苏州企业网站谷哇网站建设
  • 东营网站建设哪家更好jsp网站开发步骤
  • 嘉兴有哪些做网站的公司云南建设厅网站职称评定
  • 平面设计师常用的网站网站推广软文选择天天软文
  • 网站运营与网络推广方案凡客建设网站稳定吗
  • 网站设计哪家最好网站开发用mvc多吗
  • 网站注册属于自己的网站wordpress 上一篇 下一篇 插件
  • 如何申请一个自己的网站平台推广费用
  • 手机做网站视频织梦网站需要付费吗
  • 做百度网站营业执照用注销吗网页设计图片加背景
  • 网站建设前期准备方案上海高档网站建设
  • 上海专业做网站电话百度seo怎么把关键词优化上去
  • 安徽建站费用手游充值代理平台
  • 金融投资网站模板如何改wordpress文章模板
  • 漏惹网站做广州番禺网站建设公司推荐
  • 建设管理网站首页大数据营销的运营方式有哪些
  • 三河做网站医院建设网站与托管
  • 网站生成app 免费工具太仓手机网站建设