草庐IT

AI行为树的基础运作原理

全部标签

javascript - 正则表达式/lastIndex - 意外行为

我知道有一些正则表达式/lastIndex差异,但这对我来说是新的!预期行为:创建一个新的正则表达式(使用文字/构造函数)显然会创建一个带有lastIndex的新RegExp对象属性设置为零。实际行为:(在FF、Chrome中):lastIndex属性似乎在多个RegExp创建过程中持续存在。例如functionfoo(s){//A*NEW*regularexpression//iscreatedoneachcalloffoo():varregex=/ABC/g;document.write(regex.lastIndex+'');//regex.test()updateslastIn

javascript - 覆盖 Drupal javascript 行为

我想覆盖评论表单上的一些核心drupal行为。如果您以匿名用户的身份发表评论,您的姓名和邮件将存储在cookie中,然后javascript使用以下代码填写后续评论表单中的相应字段:Drupal.behaviors.comment=function(context){varparts=newArray("name","homepage","mail");varcookie='';for(i=0;i如果我不想填写这些字段,我知道我可以用更多的javascript删除这些信息,但我确信有一种“更干净”的方法可以做到这一点。 最佳答案 如

Javascript 原型(prototype)行为

我有一个方法可以让我在创建新对象时选择原型(prototype)对象(从“Javascript:TheGoodParts”一书复制):Object.create=function(o){varF=function(){};F.prototype=o;returnnewF();}现在说,我有一个对象:varcar={model:"Nissan"};然后我使用“Create”方法基于这个对象创建了一个新对象:varcar1=Object.create(car);然后我可以向car添加一个属性,它会动态地添加到car1(动态原型(prototype))。例如:car.year=2011;//

javascript - 带有数组的javascript的奇怪行为

让我们考虑以下JavaScript片段vararr=[];functionpushMe(){vartemp={"name":"me"};arr.push(temp)console.log(arr)temp["name"]="you";arr.push(temp)console.log(arr)}我惊讶地看到输出为[Object{name="you"},Object{name="you"}]当我们推送引用时,两者必须引用同一个对象。但至少在第一次推送之后输出必须像Object{name="me"}为什么会这样??谢谢:) 最佳答案 C

javascript - Gulp.js 与基础/compass

有没有人成功让Gulp-sass与foundation4/5一起工作(最好使用compass?)该应用程序成功地使用了基础4,没有gulp,使用compasswatch。但我想开始使用gulp来简化我的sass/coffee/minification编译。这是我的gulpfile.jsvargulp=require('gulp'),util=require('gulp-util'),sass=require('gulp-sass'),coffee=require('gulp-coffee');varpaths={scripts:{src:'src/coffee/**/*.coffee'

javascript - jQuery 选择框 .val ('' ) 行为从 1.9 到 1.10+ 不同什么是最短的方法

这个问题在这里已经有了答案:HowtosetthefirstoptiononaselectboxusingjQuery?(18个答案)关闭8年前。以下行为在jQuery1.9和1.10+之间有所不同:123$('#s1option[value=1]').hide();$('#s1').val('');这段代码背后的想法是选择第一个选项。在1.10之后,$('#s1').val('');部分不再以相同的方式工作。我想它从来没有打算以这种方式使用,而是它的旧代码必须以某种方式进行现代化......在jQuery1.10之后,没有任何选择,$('#s1').val()返回null。将代码更改

javascript - 在 JavaScript 中使用++ 时的奇怪行为

每个人都知道JavaScript中两个字符串的基本连接:>"Hello"+"World!"'HelloWorld!'但是如果我们使用++而不是+会发生什么?我刚遇到以下奇怪行为:>"Hello"++"World!"'HelloNaN'>"Hello"++""'Hello0'从上面的例子中,我可以看到第二个字符串被转换为数字。因此,将具有valueOf属性的对象作为函数传递,该函数返回的值将被转换。>"Hello"++({valueOf:function(){return1;}})'Hello1'正如预期的那样,它显示"Hello1"。为什么在Number中转换第二个字符串?为什么不抛出

javascript - 如何延迟读取带有 node.js 或 javascript 的文件行,而不是非阻塞行为?

我正在node.js中读取一个文件(300,000行)。我想以5,000行为一组将行发送到另一个应用程序(Elasticsearch)以存储它们。因此,每当我读完5,000行时,我想通过API将它们批量发送到Elasticsearch以存储它们,然后继续读取文件的其余部分并批量发送每5,000行。如果我想使用java(或任何其他阻塞语言,如C、C++、python等)来完成此任务,我将执行如下操作:intcountLines=0;StringbulkString="";BufferedReaderbr=newBufferedReader(newInputStreamReader(new

javascript - Openlayers 3 获取谷歌地图基础层?

我已经阅读了一些关于此事的帖子,其中包含指向examples的链接。但是我发现很难理解他们在示例中是如何做到的:vargmap=newgoogle.maps.Map(document.getElementById('gmap'),{disableDefaultUI:true,keyboardShortcuts:false,draggable:false,disableDoubleClickZoom:true,scrollwheel:false,streetViewControl:false});varview=newol.View({//makesuretheviewdoesn'tgo

javascript - 构造函数中的事件处理程序与构造函数外的事件处理程序的行为不同

我有一个对象的两个实例,它们扩展了EventEmitter并监听名为finish的事件。如果我在构造函数之外设置事件处理程序,一切都会按预期进行。每个实例都会听到它触发的finish的出现。但是,如果我在构造函数中设置事件处理程序,则只有第二个创建的实例会听到事件并对事件使用react,或者看起来是这样。代码如下:varutil=require('util');varEventEmitter=require('events').EventEmitter;varfs=require('fs');varNEXT_ID=0;varMyEmitter=function(){EventEmitt