JS/TS笔记学习1

周末总得学点什么吧~
奥利给!

  • 跑火车 递归 减速
let currentIndex = 0;  
let speed = 500; // 初始速度,单位是毫秒  
let decrement = 20; // 每次迭代速度减少的量  const cells = document.querySelectorAll('.cell');  function highlightCell() {  cells.forEach((cell, index) => {  cell.classList.remove('highlight');  if (index === currentIndex) {  cell.classList.add('highlight');  }  });  if (speed > 50) { // 当速度降低到一定程度时停止  speed -= decrement;  setTimeout(highlightCell, speed);  currentIndex = (currentIndex + 1) % cells.length; // 移动到下一个格子  }  
}  highlightCell(); // 开始跑火车
  • 队列
/*** 将弹窗加入弹出窗队列* @param {string} panelPath * @param {string} scriptName * @param {*} param */public pushToPopupSeq(panelPath: string, scriptName: string, param: any) {let popupDialog = {panelPath: panelPath,scriptName: scriptName,param: param,isShow: false};this._arrPopupDialog.push(popupDialog);this._checkPopupSeq();}/*** 检查当前是否需要弹窗*/private _checkPopupSeq() {if (this._arrPopupDialog.length > 0) {let first = this._arrPopupDialog[0];if (!first.isShow) {this.showDialog(first.panelPath, first.param);this._arrPopupDialog[0].isShow = true;}}}/*** 将弹窗从弹出窗队列中移除* @param {string} panelPath */public shiftFromPopupSeq(panelPath: string) {this.hideDialog(panelPath, () => {if (this._arrPopupDialog[0] && this._arrPopupDialog[0].panelPath === panelPath) {this._arrPopupDialog.shift();this._checkPopupSeq();}})}
  • ts给readonly属性赋值
    除了在声明它的类或构造函数内部被赋值,有些情况下(静态只读)可能需要赋值
class TweenSystem {  static readonly instance; // 声明静态只读属性  如何赋值呢??? 请看下面  // ... 其他代码保持不变 ...  public getNum(){console.log(123);}
}
//这种情况如何赋值只读属性呢,看下面
// 在类外部初始化 instance  
(TweenSystem.instance as any) = new TweenSystem();  
// 现在可以正确访问了  
const actionMgr = TweenSystem.instance;
actionMgr.getNum();   //123

那么为什么as any后就可以赋值(TweenSystem.instance as any);
TweenSystem.instance as any 的情况下,通过类型断言将 TweenSystem.instance 的类型临时转换为 any,从而能够给它赋值。尽管这样做在技术上是可行的,但它破坏了 TypeScript 的类型安全原则,并可能导致运行时错误或难以追踪的 bug。
通常,不建议使用类型断言来修改 readonly 属性,除非有非常明确的原因,并且完全理解可能带来的后果。如果需要在类的外部初始化 readonly 属性,更好的做法是在类的内部进行初始化

  • 单例模式
class Singleton {  // 使用一个私有的静态实例变量来存储类的唯一实例  private static instance: Singleton | null = null;  // 构造函数是私有的,这样外部就无法使用 new Singleton() 来创建新的实例  private constructor() {  // 初始化代码(如果有的话)  }  // 提供一个静态方法来获取类的唯一实例  // 如果实例不存在,则创建它  public static get getInstance(): Singleton {  if (Singleton.instance === null) {  Singleton.instance = new Singleton();  }  return Singleton.instance;  }  // 类的其他方法或属性  public someMethod() {  console.log("这是 Singleton 类的一个方法");  }  
}  
// 使用示例  
const singletonInstance = Singleton.getInstance;  
singletonInstance.someMethod(); // 调用 Singleton 类的方法   //out: 这是 Singleton 类的一个方法

而有些情况下也可以直接这样

class Singleton1 {  static readonly instance = new Singleton1();  // 构造函数是私有的,这样外部就无法使用 new Singleton1() 来创建新的实例  private constructor() {  // 初始化代码(如果有的话)  console.log("在编译完就直接创建了,不管你有没有调用")}// 类的其他方法或属性  someMethod() {  console.log("这是 Singleton1 类的一个方法");  }  
}  // 使用示例  
const Singleton1Instance = Singleton1.instance;  
Singleton1Instance.someMethod(); // 调用 Singleton1 类的方法

在这里插入图片描述
区别就在于编译后直接创建了单例,但基本上很少采用这种

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/823513.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Boost电感的作用

Boost电感在Boost升压电路中起着关键的作用。Boost电路是一种DC-DC电源转换器,其主要功能是将低电压直流(DC)信号转换为高电压直流(DC)信号。Boost电感在这个过程中起着平滑电流、储存能量和提高电路效率的作用。 具体…

柯桥商务口语之怎么样说英语更加礼貌?十个礼貌用语get起来!

当你在国外需要帮助的时候,这些礼貌用语真的是能够帮到你的哦 1.Would/Could you help me? 你可帮助我吗? 相信有些人想请求帮助的时候,一开口就用Can you,这个用在朋友或者熟人上面当然是没有问题的,但是如果是向…

Node.js 中的 RSA 加密、解密、签名与验证详解

引言 在现代的网络通信中,数据安全显得尤为重要。RSA加密算法因其非对称的特性,广泛应用于数据的加密、解密、签名和验证等安全领域。本文将详细介绍RSA算法的基本原理,并结合Node.js环境,展示如何使用内置的crypto模块和第三方库…

基于 LSTM 模型的古诗词自动生成算法实现及系统实现

近年来,研究者在利用循环神经网络(Recurrent Neural Network,RNN)进行古诗自动生成方面取得了显著的效果。但 RNN 存在梯度问题,导致处理时间跨度较长的序列时 RNN 并不具备长期记忆存储功能。随后,出现的基…

【架构方法论(一)】架构的定义与架构要解决的问题

文章目录 一. 架构定义与架构的作用1. 系统与子系统2. 模块与组件3. 框架与架构4. 重新定义架构:4R 架构 二、架构设计的真正目的-别掉入架构设计的误区1. 是为了解决软件复杂度2. 简单的复杂度分析案例 三. 案例思考 本文关键字 架构定义 架构与系统的关系从业务逻…

企业linux-堡垒机与跳板机测试案例-6140字详谈

在开始今天内容前,小编先把专栏前面学的Linux命令(部分)做了思维导图帮助各位平时的学习: 场景: 运维人员管理三台机器,通过远程连接工具连接上三台机器,也知道这三台机器root密码&#xff0c…

【Java探索之旅】掌握数组操作,轻松应对编程挑战

🎥 屿小夏 : 个人主页 🔥个人专栏 : Java编程秘籍 🌄 莫道桑榆晚,为霞尚满天! 文章目录 📑前言一、数组巩固练习1.1 数组转字符串1.2 数组拷贝1.3 求数组中的平均值1.4 查找数组中指…

Windows版Apache 2.4.59解压直用(免安装-绿色-项目打包直接使用)

windows下Apache分类 Apache分为 安装版和解压版 安装版: 安装方便,下一步------下一步就OK了,但重装系统更换环境又要重新来一遍,会特别麻烦 解压版(推荐): 这种方式(项目打包特别方便&#x…

【全国青少年信息素养大赛】初中模拟题

智能算法挑战赛初中模拟(一)卷 单选题(每题 5 分,共 75 分) 1. 人工智能技术通常不包括以下哪项技术? A. 机器学习 B. 深度学习 C. 物联网技术 D. 自然语言处理 2. 在C中,用于输出数据到控制台的函数是? A…

力扣哈哈哈哈

public class MyStack {int top;Queue<Integer> q1;Queue<Integer> q2;public MyStack() {q1new LinkedList<Integer>();q2new LinkedList<Integer>();}public void push(int x) {q2.offer(x);//offer是入队方法while (!q1.isEmpty()){q2.offer(q1.pol…

HPTNet:为点云提取表面特征

论文题目&#xff1a;High-Performance Feature Extraction Network for Point Cloud Semantic Segmentation 论文地址&#xff1a;https://ieeexplore.ieee.org/abstract/document/10474110 文章目录 1. 平面几何特征的提取2. 几何和语义特征的分开处理3. Transformer模块4. 结…

MySQL基础知识——MySQL事务

事务背景 什么是事务&#xff1f; 一组由一个或多个数据库操作组成的操作组&#xff0c;能够原子的执行&#xff0c;且事务间相互独立&#xff1b; 简单来说&#xff0c;事务就是要保证一组数据库操作&#xff0c;要么全部成功&#xff0c;要么全部失败。 注&#xff1a;MyS…

2024.4.17 iic

main.c #include "si7006.h"int main() {//si7006初始化si7006_init();i2c_init();unsigned short hum;short tem;while(1){//读取温度和湿度humsi7006_read_hum();temsi7006_read_tem();//计算温湿度数据humhum*125/65536-6;temtem*175.72/65536-46.85;printf(&quo…

代码随想录算法训练营第一天 | 704. 二分查找 | 27. 移除元素

704. 二分查找 int search(int* nums, int numsSize, int target) {int left 0, right numsSize, mid;while (left < right) {mid left (right -left) / 2;if (nums[mid] < target) {left mid 1;} else if (nums[mid] > target) {right mid;} else {return mid…

浅谈C语言中异或运算符的10种妙用

目录 1、前言 2、基本准则定律 3、妙用归纳 4、总结 1、前言 C语言中异或运算符^作为一个基本的逻辑运算符&#xff0c;相信大家都知道其概念&#xff1a;通过对两个相同长度的二进制数进行逐位比较&#xff0c;若对应位的值不同&#xff0c;结果为 1, 否则结果为 0。 但是…

《构建高效ERP系统:数据库字段命名的艺术与实践》

当设计大型ERP系统的数据库时&#xff0c;合理的字段命名是至关重要的。良好的字段命名原则和实践可以提高数据库的可读性、可维护性和性能。本文将探讨在设计大型ERP系统数据库时应该遵循的字段命名原则&#xff0c;并结合实际案例进行说明。 清晰明了的命名&#xff1a;字段名…

CMMI认证是什么?如何确定CMMI认证的目标和范围

CMMI&#xff08;Capability Maturity Model Integration&#xff09;认证是一种用于评估和改进组织软件和项目管理过程的框架。它由美国国防部软件工程所&#xff08;SEI&#xff09;开发&#xff0c;旨在帮助组织提高其软件和项目管理的成熟度水平。 CMMI认证的意义在于&…

哪里有su材质库免费下载?

su材质库是一套草图大师的通用材质大全&#xff0c;包含多种不同类型的材质包和材质贴图&#xff0c;使得设计师能够轻松在电脑上进行直观的构思。对于需要免费下载su材质库的用户&#xff0c;可以尝试通过以下途径获取。 1. 官方网站查找&#xff1a;许多软件都会在官网上提供…

第十六篇:springboot案例

文章目录 一、准备工作1.1 需求说明1.2 环境搭建1.3 开发规范1.4 思路 二、部门管理2.1 查询部门2.2 删除部门2.3 新增部门2.4 修改部门2.5 RequestMapping 三、员工管理3.1 分页查询3.2 删除员工3.3 新增员工3.3.1 新增员工3.3.2 文件上传 3.4 修改员工3.4.1 页面回显3.4.2 修…

【数据结构】-- 栈和队列

&#x1f308; 个人主页&#xff1a;白子寰 &#x1f525; 分类专栏&#xff1a;python从入门到精通&#xff0c;魔法指针&#xff0c;进阶C&#xff0c;C语言&#xff0c;C语言题集&#xff0c;C语言实现游戏&#x1f448; 希望得到您的订阅和支持~ &#x1f4a1; 坚持创作博文…