草庐IT

value-class

全部标签

javascript - 扩展挑战 : preprocessor function macros and class-like oop

背景我一直在使用C预处理器来管理和“编译”具有多个文件和构建目标的半大型javascript项目。这允许从javascript中完全访问C预处理器指令,如#include、#define、#ifdef等。这是一个示例构建脚本,因此您可以测试示例代码:#!/bin/bashexportOPTS="-DDEBUG_MODE=1-Isrc"forFILEin`findsrc/|egrep'\.js?$'`doecho"Processing$FILE"cat$FILE\|sed's/^\s*\/\/#/#/'\|cpp$OPTS\|sed's/^[#:build/`basename$FILE`

javascript - 为什么 "[value=' ' ]"throw an exception in IE7 and ":not(:not([value ='' ]))"does not?

我正在尝试通过jQuery从选择框中选择选项标签(值为“”的选项)。我使用以下选择器:$("[value='']");这适用于大多数浏览器,但在IE7中它会抛出异常。如果我将其更改为以下(恕我直言)选择器,则它可以正常工作:$(":not(:not([value='']))");我宁愿不使用后者,但想不出更好的等价物。编辑:jQuery版本:1.3.1.异常:MicrosoftJScript运行时错误:抛出异常但未捕获在if(S==null){throw"Syntaxerror,unrecognizedexpression:"+ab}在哪里ab="value='']"测试设置:为确保我

javascript - 如何创建将方法添加到原型(prototype)并正确使用 "class"的 JavaScript 'this'

这个问题在这里已经有了答案:Howdoesthe"this"keywordwork,andwhenshoulditbeused?(22个答案)关闭8年前。我一直被教导在JavaScript中模拟类的正确方法是在将成为类的函数之外的原型(prototype)中添加方法,如下所示:functionmyClass(){this.myProp="foo";}myClass.prototype.myMethod=function(){console.log(this);}myObj=newmyClass();myObj.myMethod();我一直遇到this的问题在我的方法中解析为全局Wind

javascript - 代码挑战 : Create a class Foo that tracks the number of total object instances

我正在尝试解决工作应用程序的代码挑战,但我遇到了困难,非常感谢任何帮助。问题:创建一个Foo类,它有一个名为refCount的方法。在类或其任何实例上调用refCount应该返回存在的实例总数。示例:varf1=newFoo();f1.refCount();//shouldbe1Foo.refCount();//shouldbe1varf2=newFoo();f1.refCount();//shouldbe2f2.refCount();//shouldbe2Foo.refCount();//shouldbe2到目前为止我有这样的事情:functionFoo(){this.refCoun

javascript - {...object, property : value} work with spread syntax? 如何

在查看ES6文档时,我注意到建议使用扩展语法而不是更冗长的Object.assign()方法。但是,我对这是如何实现的有点困惑。在这种情况下object是否被分解为key:value对,之后添加或覆盖逗号右侧的属性,最后被重新组装? 最佳答案 Isobjectinthiscasebeingbrokendowntokey:valuepairs,afterwhichthepropertyontherightofthecommaiseitheraddedoroverwritten,andfinallybeingreassembled?原始

javascript - RequireJS 模块的 TypeScript 编译生成行 Object.defineProperty(exports, "__esModule", { value : true }); How to get rid of it?

这是我的tsconfig.json文件的样子:{"compileOnSave":true,"compilerOptions":{"module":"amd","noImplicitAny":false,"removeComments":false,"preserveConstEnums":true,"strictNullChecks":true,"sourceMap":false}}我有一个名为a.ts的typescript文件,它是一个AMD模块(我正在使用requirejs),它看起来像:exportfunctiona(){vara={b:5};returna;}编译后的Javas

javascript - 如何使用 Bluebird 在构造函数构建的 "class"上 promise 导出的函数

我有一个服务,PageService,我这样测试(简化)...vardatabase=require("../database/database");varPageService=require("./pageService");describe("PageService",function(){varpageService={};before(function(done){pageService=newPageService(database);}it("cangetallPages",function(done){pageService.getAll(function(err,pa

javascript - ESLint 的 "consistent return"规则的值(value)主张是什么?

对于不需要显式返回任何内容的函数,始终返回一个值(“未定义”)有什么值(value)?为什么这是一条规则,它会捕获哪些错误?您可以阅读ESLint的“一致返回”规则here(回答“是什么”,而不是“为什么”)。您可以阅读关于为什么javascriptfunctionsimplicitlyreturnsundefined的推测性分析这里是堆栈溢出。 最佳答案 一些语言区分函数和过程。在类C语言中情况并非如此,但以这种方式设计子例程仍然是一个好主意。linter不希望您“总是返回一些东西”。它只是告诉您,如果您设计一个函数(而不是一个过

javascript - Redux 中间件设计 re : return values

所以我刚刚阅读了redux中间件,听起来不错。不过有一件事困扰着我——中间件的返回值。我知道中间件的某些实例会返回一些东西(即redux-promise),而我得到其他中间件(即logging)不会-只是返回next(action)的结果。我的问题是,如果我想使用两个都返回内容的中间件会发生什么——它们肯定会互相破坏,而我只会获得最外层中间件的返回值。express/connect中间件通过让中间件将其“结果”写入req和res对象来解决这个问题,但是解决方案是什么还原?编辑这是我的问题的一个更具体的例子:我有两个中间件:将所有操作延迟3秒分派(dispatch)的中间件。这个中间件返

javascript - Array.find(value) 返回值 'is not a function'

我正在尝试在AngularJS数组上使用JavaScript的find()函数。这是合法的,对吧...?这个非常简单的代码给我带来了一些问题。这是说$scope.names.find(name1)的返回值不是函数。TypeError:Name1不是函数if($scope.names.find(name1)!==name1){$scope.names.push(name1);}我也试过...if($scope.names.find(name1)===undefined){$scope.names.push(name1);}和if(!$scope.names.find(name1)){$s