首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么不是0,1,2,3,4?setTimeout的奇怪问题

网上看到这样一个题目: for(let i=0;i<5;i++){ setTimeout(function(){alert(i)},0) } 它输出的顺序并不是0,1,2,3,4,也不是固定的某一个顺序的数字...其实这里有三个关键点, 1、let,它声明了一个块级作用域; 2、alert,它引起了js的阻塞; 3、setTimeout添加到js队列; 简单的讲, 1、js中没有任何可以立即执行的代码,它们都是需要被添加到队列中...2、setTimeout并不是指定了间隔时间就一定会按指定时间执行。它只是说“在指定时间之后,加入队列,等待执行”。至于什么时候执行,要看进程队列的空闲程度。...3、alert()它会阻塞js的执行,此时js进程是暂停的。 4、题目中使用的是let,这相当于是使用闭包的方式来传入值。如果是var,那么就是直接执行完i=5之后再执行alert了。...这个题目很简单,但包含了几个关键的知识点,我把这个题目添加到了先行者旗下的js问答小组之中, 在我收到的回复邮件中,这个同学的回答很靠谱, ?

66890

4种方法实现ggplot2的aes()中的变量替换

介绍 ggplot2里aes()可以用tidyselect风格去选择变量做映射绘图,那么这种情况下如何实现「变量替换」呢? 首先说下我为什么要实现「变量替换」。...我目前实际的需求就是,分析代码+绘图代码篇幅太长,在封装流程的时候我想要把变量提到前面,通过替换一个变量来避免后面多次修改替换变量。 方法与演示 有!!as.name()、get()、!!...sym()和.data[[]] 共计四种有效方法在aes()中实现变量替换。...代码演示如下: library(ggplot2) # 创建一个包含变量的数据框 data <- data.frame( x = c(1, 2, 3, 4), y = c(10, 20, 30,...40), group = c("A", "A", "B", "B") ) # 定义一个变量,用于替换图形属性 color_var <- "group" # 使用变量替换创建散点图 ggplot

27610
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    OpenAI 最新“神”操作:让 GPT-4 去解释 GPT-2 的行为!

    此前,即便是专业的数据科学家,都难以解释大模型(LLM)运作的背后。而最近,OpenAI 似乎做到了——本周二,OpenAI 发布了其最新研究:让 GPT-4 去试着解释 GPT-2 的行为。...由于 AI 的“黑盒”性质,人们很难分辨大模型的输出结果是否采用了带有偏见性质的方法,也难以区分其正确性,因而“可解释性”是亟待重要的一个问题。...让 GPT-4 “解释” GPT-2 的原理 具体来说,让 GPT-4 “解释” GPT-2 的过程,整体分为三个步骤。...(1)首先,让 GPT-4 生成解释,即给出一个 GPT-2 神经元,向 GPT-4 展示相关的文本序列和激活情况,产生一个对其行为的解释。...如上图所示,GPT-4 对 GPT-2 该神经元生成的解释为:与电影、人物和娱乐有关。 (2)其次,再次使用 GPT-4,模拟被解释的神经元会做什么。下图即 GPT-4 生成的模拟内容。

    25130

    浅谈 Angular 项目实战

    其中使用 ng build 打包后可能会有资源引用错误的问题,可以看一下使用 ng build 构建后资源地址引用错误的问题。...entryComponents: [ModalAlertComponent, ModalConfirmComponent] }) 还有一点需要注意,在使用模板引用变量时,不要和函数名重名,有时图省事可能会忽略这一点...不过 Angular 的模板驱动表单并没有复选框的多选绑定,如果有这个需求,可以选择更加灵活强大的响应式表单进行数据绑定。其实,对于数组形式的数据可以使用天然的 select 多选框实现。...然而复选框的 value 值只有 true 或者 false,而 select 多选框的 value 值就是数组。所以 Vue 对复选框的多选操作进行了处理,而 Angular 没有,需要你自己处理。...我们用一个最常见的数据映射例子说明,比如保存性别数据时,1 表示男,2 表示女。

    4.6K00

    IntelliJ IDEA 2022.2.2汉化版免登陆账号「winmac」

    2、编辑- 跳转到闭合括号/引用Tab现在,在键入时,您可以使用Tab在结束括号或结束引号之外导航。...要启用此 Tab行为,请转到首选项/设置| 编辑| 一般| 智能键并选择跳转到关闭括号外/使用Tab键引用- 为重新分配的局部变量和重新分配的参数加下划线IntelliJ IDEA现在默认为重新分配的局部变量和重新分配的参数加下划线...UI元素(如按钮,单选按钮,复选框,文本字段,选择控件,微调器和选项卡)的外观已更新。4、版本控制- 更容易解决合并冲突使用Git时,现在查找包含合并冲突的文件要容易得多。...在IDE中启动带有coverage的JavaScript Debug配置,并在Chrome中与您的应用进行交互。然后停止配置,IntelliJ IDEA将在Coverage工具窗口中显示覆盖率报告。...- 与Angular CLI的新集成在IntelliJ IDEA 2019中,由于与ng add的集成,您可以为Angular应用程序添加新功能。

    4.7K30

    A4第四章第2节null和成员变量、局部变量的不同初始化

    A4第四章第2节null和成员变量、局部变量的不同初始化第4节 1、null表示变量没有指向任何对象 如:Person p=null; p.sayHello();//结果会抛出异常 2...A4第四章第2节定义类字段方法及实例化类 第四章第2节 1、字段不加public,定义的方法加public 2、方法一般是大写开头 3、最简单的类:class Person{} 4、增加类变量(字段...命名空间语法: namespace ConsoleApplication1包住类; 当前命名空间中的类无需引用;使用using引用其他包中的类: 还可以直接通过“命名空间+类名”的方式使用“System.Data.SqlClient.SqlConnection...接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法。...然后,它可以在实现了该接口的类的任何对像上调用接口的方法。由于有抽像类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。

    54210

    一起长锈:4 默认不可变的变量绑定与引用(从Java与C++转Rust之旅)

    赵可菲:“嘿,为啥Rust要设计变量绑定这样的机制呢?有啥好处不?” 贾克强:“Rust的变量绑定跟Java或C++的赋值不一样,其实主要是体现了更深的语言设计原则和变量行为的差别。”...5 | 2 | *x += 1; // 尝试修改通过不可变引用传递的值 | ^^^^^^^ `x` is a `&` reference, so the data it refers...支持不可变 (const T*) 和可变 (T*) 引用。 所需库支持 标准库中包含丰富的函数和宏来支持安全的引用操作。 标准库中不包含专门支持引用操作的特殊库,引用被视为对象的默认行为。...引用的默认行为 默认情况下,引用指向的数据是不可变的。要修改通过引用访问的数据,必须显式使用可变引用(&mut)。...最后,文章通过一些代码示例讲解了Rust,Java和C++中引用和解引用的不同用法和行为,以及Rust与C++的解引用操作的异同。

    23943

    AngularDart 4.0 高级-管道 顶

    每个应用程序都以一个简单的任务开始:获取数据,转换它们,并将它们展示给用户。 获取数据可以像创建本地变量一样简单,也可以像通过WebSocket传输流数据一样复杂。...在前面的例子中,你没有列出DatePipe,因为所有的Angular内置管道都是预先注册的。 要在实例中查看行为(查看源代码),请更改模板中的值和可选的指数。...List transform(List value) => value.where((hero) => hero.canFly).toList(); } 请注意实例中的奇怪行为...虽然你没有得到你想要的行为,但Angular并没有被破坏。 它只是使用不同的变更检测算法,忽略对列表或其任何项目的更改。...Flying Heroes应用程序通过复选框开关和附加显示扩展代码,以帮助您体验这些效果。 ? 替换列表是发信号通知Angular更新显示的有效方式。 你什么时候更换清单? 数据发生变化时。

    6.4K20

    Angular快速学习笔记(3) -- 组件与模板

    如果你要引用的变量名存在于一个以上的命名空间中,那么,模板变量是最优先的,其次是指令的上下文变量,最后是组件的成员。...'red' : 'green'"> 模板引用变量 ( #var ) 模板引用变量通常用来引用模板中的某个 DOM 元素,它还可以引用 Angular 组件或指令或Web Component。...使用井号 (#) 来声明引用变量。#phone 的意思就是声明一个名叫 phone 的变量来引用 元素。...在这种模式下,有类型的变量默认是不允许 null 或 undefined 值的,如果有未赋值的变量,或者试图把 null 或 undefined 赋值给不允许为空的变量,类型检查器就会抛出一个错误 Angular...属性型指令 — 改变元素、组件或其它指令的外观和行为的指令。

    15.3K30

    看我如何利用漏洞窃取麦当劳网站注册用户密码

    q={{$id}} AngularJS是一个流行的JavaScript框架,通过这个框架可以把表达式放在花括号中嵌入到页面中。 例如,表达式1+2={{1+2}}将会得到1+2=3。...其中括号中的表达式被执行了,这就意味着,如果服务端允许用户输入的参数中带有花括号,我们就可以用Angular表达式来进行xss攻击。...在这里,我们来看看McDonalds.com使用的AngularJS版本,通过在浏览器控制端输入angular.version命令: 可以发现AngularJS为1.5.3版本,参照PortSwigger...窃取密码 除此之外,我在麦当劳网站的注册页面发现了复选框“Remember my password”,通常来说,这只有在用户登录页面才存在,有点奇怪: 在该页面的源代码页面,包含了各种passowrd字段内容...,甚至存在一个有趣的密码解密函数: 最危险的是,利用该解密函数代码竟然可以实现对客户端或双向加密存储的密码破解。

    2K60

    AngularDart 4.0 高级-结构指令 顶

    microsyntax解析器将该字符串转换为上的属性: let关键字声明了模板中引用的模板输入变量。这个例子中的输入变量是hero,i和odd。...当你编写自己的结构指令时,可以使用这些微观语法机制。 研究NgIf和NgFor的源代码是了解更多信息的好方法。 模板输入变量 模板输入变量是一个变量,其值可以在模板的单个实例中引用。...在这个例子中有几个这样的变量:hero,i和odd。 所有前面都有关键字let。 模板输入变量与模板引用变量不同,语义和语法都不同。 您使用let关键字(let hero)声明模板输入变量。...变量的作用域限于重复模板的单个实例。 您可以在其他结构指令的定义中再次使用相同的变量名称。 您通过在#(#var)前缀加上变量名称来声明一个模板引用变量。 引用变量是指其附加的元素,组件或指令。...它可以在整个模板中的任何地方访问。 模板输入和引用变量名称都有其自己的名称空间。 let hero中的hero变量永远不会和#hero中的hero一样。

    16.1K20

    Angular 2 用户输入

    用户点击链接、按下按钮或者输入文字时,这些用户的交互行为都会触发 DOM 事件。 本章中,我们将学习如何使用 Angular 事件绑定语法来绑定这些事件。...---- 从一个模板引用变量中获得用户输入 你可以通过使用局部模板变量来显示用户数据,模板引用变量通过在标识符前加上井号 (#) 来实现。...box 变量引用的就是 元素本身,这意味着我们可以获得 input 元素的 value 值,并通过插值表达式把它显示在 标签中。...我们可以使用模板引用变量来修改以上 keyup 的实例: app/keyup.components.ts (v2) 文件: @Component({ selector: 'key-up2', template...Angular 可以为我们过滤键盘事件,通过绑定到 Angular 的 keyup.enter 伪事件监听回车键的事件。

    1.7K20

    详解ANGULAR2组件中的变化检测机制(对比ANGULAR1的脏检测)

    组件和变化检测器 如你所知,Angular 2 应用程序是一颗组件树,而每个组件都有自己的变化检测器,这意味着应用程序也是一颗变化检测器树。顺便说一句,你可能会想。是由谁来生成变化检测器?...Angular 2 编译器为每个组件自动创建变化检测器,而且最终生成的这些代码 JavaScript VM友好代码。...虽然 Angular 2 优化后的变化检测执行的速度很快,但我们能否只针对那些有变化的组件才执行变化检测或灵活地控制变化检测的时机呢 ? 答案是有的,接下来我们看一下具体怎么进行优化。...变化检测策略 在 Angular 2 中我们可以在定义组件的 metadata 信息时,设定每个组件的变化检测策略。...不过,我们还有其他方法来获得更好的性能。 即使用 Observable 与 ChangeDetectorRef 对象提供的 API,来手动控制组件的变化检测行为。

    2.9K90

    AngularDart4.0 指南- 表单 顶

    -- TODO: remove the next diagnostic line --> {{spy.className}} 模板引用变量 spy模板引用变量绑定到 DOM元素,而name...指令的exportAs属性告诉Angular如何将引用变量链接到指令。 您将name设置为“ngForm”,因为ngModel指令的exportAs属性是“ngForm”。...删除#spy模板引用变量和使用它的诊断。 作为类绑定的替代方法,可以使用NgClass指令来设置控件的样式。...如果没有Angular的帮助,你需要做什么才能将按钮的启用/禁用状态连接到表单的有效性? 对你来说,这很简单: 在(增强的)表单元素上定义一个模板引用变量。 在多处的按钮中引用该变量。...输入控件(通过模板引用变量访问)的valid 属性,用于检查控件有效性以及显示/隐藏错误消息。 NgForm.form的有效性来设置提交按钮的启用状态。

    17.5K30

    【AngularJS】 # AngularJS入门

    通过内置的指令来为应用添加功能,可以自定义指令。 指令带有前缀 ng- ng-app指令用来初始化一个 AngularJS应用程序 3.1....-- 获取变量的值 --> var app = angular.module("myApp", []); app.controller("myCtrl", function...复选框(Checkbox) checkboc的值为 true 或 false ,可以使用 ng-model 指令绑定,值可以用于应用中 选中复选框...var obj2 = angular.copy(obj) 比较对象 angular.equals() var obj1 = { a: 1}; var obj2 = obj1; // 引用一致...AngularJS 依赖注入 依赖注入(DI):是一种软件设计模式,在这种模式下,一个或更多的依赖(或服务)被注入(或者通过引用传递)到一个独立的对象(或客户端)中,然后成为了该客户端状态的一部分。

    23.2K60

    Angular v8 发布!来看看有什么新功能

    /n-queens'; 2 3addEventListener('message', ({ data }) => { 4 const result = nQueens(data.count); 5...它们可以存储在例如 browserslist 文件中,CLI 在生成新项目时同时会在 projectroot 中创建: 1> 0.5% 2last 2 versions 3Firefox ESR 4not...为了使不同的浏览器可以决定要加载哪个版本的 bundle 包,他们在 index.html 添加中接受 script 的引用:指向 ECMAScript 5 包的那些引用会添加 nomodule。...由于这种行为十分令人困惑,所以现在组件必须指定何时应该进行解决: 1@ViewChild('info', { static: false }) 2 paragraph: ElementRef; 如果...ng update 命令 会自动尝试在此处输入正确的值。如果无法做到这一点,则会在其位置添加带有 TODO 的注释。

    3K30

    再谈angularJS数据绑定机制及背后原理—angularJS常见问题总结

    两者的区别在于页面没有加载完毕 {{val}} 会直接显示到页面,直到 Angular 渲染该绑定数据(这种行为有可能将 {{val}} 让用户看到);而 ng-bind 则是在 Angular 渲染完毕后将数据显示...,如果不加第三个参数 true ,在 data.name 变化时,不会触发相应操作,因为引用的是同一引用。...其实不必考虑那么多,总之加上没坏处,至少可以避免 angular 生成 $$hashKey 这种奇奇怪怪的东西。 具体参看: 详解track by 脏检测的利弊?...,增加一列复选框或者一列按钮啥的,这是就需要用到$compile了。...$compile解说推荐看《Angular中$compile源码分析》 这篇是对angularJS的一些疑点回顾,文章的问题大多是从网上搜集整理而来,如有不妥之处或不远被引用,请通知本人修改,谢谢!

    7.9K40

    8-angular 要点温习-1

    () angular.isDefined() angular.isElement() angular.isFunction() 如果引用的是函数返回 true angular.isNumber()...isNaN($scope.myInput); angular.isObject() 如果引用的是对象返回 true angular.isString() 如果引用的是字符串返回 true angular.isUndefined...() 如果引用的未定义返回 true angular.equals(a,b) 如果两个对象相等返回 true *angular.fromJson() 反序列化 JSON 字符串 *angular.toJson...> 复制代码 4、怎么在 angular 架构中创建编译元素 添加新的元素则需要通过编译实现,编译的目的在于让添加的脚本代码支持ng-?...$error.number 带有数量验证的文本输入。也可以有最小和最大值的附加属性。 $error.date 带有输入日期文本输入。 $error.url 带有输入验证的URL文本输入。

    3.3K40
    领券