草庐IT

javascript - 有没有办法在 JS 中比较两种颜色,比如 'If Color A is darker than #202020'

我的一个页面的背景颜色是从用户设置为他们的Twitter背景颜色的背景颜色中提取的。我有一个带有黑色边框的圆框的页面。如果背景颜色很暗,边框看起来不太好,所以我想删除比任意十六进制颜色更暗的背景边框。我考虑这样做的方法是使用正则表达式提取3个RGB值并将它们相加,然后将其与我的引用颜色进行比较。有没有更好的方法来实现这一目标? 最佳答案 您可以编写一个在RGB和HSL或HSV之间转换的函数,并使用亮度或亮度值。维基百科有HSV->RGB转换的数学,但没有其他方法。http://en.wikipedia.org/wiki/HSL_an

javascript - 将 "if/then..else"语句与 "switch"语句组合

我必须并排显示两个数字(都以zero.gif文件开始)。每个数字都需要一个输入区域供用户输入1到5之间的数字和一个显示“处理编号”的按钮,然后相应的数字就会弹出。我必须对一个使用if-then-else语句,对另一个使用switch语句。我分别了解这两者,但我不确定如何在脚本代码中将两者结合起来。目前,当我在第一个输入框中输入一个数字时,两者同时变化。如果我尝试第二个框,我会收到警告“您必须选择1到5之间的数字。”所以我不确定如何将两者分开。我使用了不同的图像ID,但它不起作用。这是所有代码。functionprocessNumber(){varnumberInput=document

javascript - AngularJS ng-if 指令在删除元素之前即使条件为假也会短暂呈现

在下面的模板中,我希望脚本标签永远不会呈现,警报脚本也永远不会执行。然而它确实如此。alert('shouldnotrun')Shouldnotappear这给我们在移动设备上带来了巨大的性能问题,因为我们将大型DOM和指令结构包装在ng-if中,并期望它们在条件为假时不会呈现。我还测试了以相同方式运行的ng-switch。这是预期的行为吗?有没有办法避免不必要的渲染?JSFiddle 最佳答案 这可能看起来很落后,但ngIf更多地处理DOM的删除,而不是添加。在Controller完成实例化之前,DOM仍然存在。这通常是一件好事,

javascript - ng-repeat 忽略立即 ng-if

我已经使用AngularJS很长时间了,但现在遇到了一个奇怪的问题,即ng-if被ng-repeat忽略了。这是无法按预期工作的示例和简单代码{{detail.name}}{{detailed.prof}}Printthis(Updated)这是我的plunkr:https://plnkr.co/edit/xy4Qyd4tXm6kWROiaFVR?p=preview 最佳答案 使用这个版本或者使用ng-if->ng-show 关于javascript-ng-repeat忽略立即ng-if

javascript - if block 是否在函数作用域内创建一个新的局部作用域?

例如:functionexample(){console.log("outsidetheifblockabovefunctionbdeclaration"+b());functiona(){return"youinvokedfunctiona";}if(true){console.log("insidetheifblock"+a());console.log("insidetheifblockabovefunctionbdeclaration"+b());functionb(){return"youinvokedfunctionb";}}}当我调用这个example()函数时,我得到一

javascript - navigator.geolocation.getCurrentPosition() : fire callback if user says "no"?

这是我的代码的近似值:if(navigator.geolocation){navigator.geolocation.getCurrentPosition(function(position){//success!},function(error){//error},{timeout:10000});}else{//yourbrowser/devicedoesn'tsupportgeolocation}当这段代码运行时,浏览器会正确地请求用户允许跟踪他们的物理位置。如果用户说"is",它会正确运行第一个参数(“成功”)指定的函数。我不清楚的是当用户说“不”时会发生什么。到目前为止,在我

javascript - if 语句中的逗号

我在一些JavaScript中遇到过一个相当令人困惑的语句:if(n="value",a==b){...我认为这是先给n赋值,然后比较(a==b)判断是否继续if声明。但为什么?这样做比说...有什么好处吗?n="value";if(a==b){...或者...if(a==b){n="value";... 最佳答案 在JavaScript中,无论何时将多个表达式放在一对括号内,它们都会被计算为最后一个表达式,如下例所示:vara=(1,2);varb=a+1;//b=2+1=3因此,在您的情况下,解释器执行属性n="value",然

javascript - Angular 2 自定义验证器 : check if the input value is an integer?

在Angular2项目中,我需要验证一些输入。如何轻松检查输入值是否为整数?我尝试使用Number(control.value)为空字段返回0-不好。或parseInt(control.value,10)不考虑空格:如果我有类似的东西:1space0,24=1,024它返回1-它通过了验证器没有错误。Lodash函数如:_.isInteger(control.value)或_.isNumeric(control.value)//每次都返回false-这是预期的,因为输入值是字符串而不是数字。像这样组合方法会创建一个包含许多if/else语句的困惑函数,即便如此,我也不确定我是否得到了所

javascript - 如何在 JavaScript 中没有大量 if 语句的情况下避免 "the property of undefined"错误?

我经常发现自己在处理像这样的深层物体:varx={y:{z:{a:true}}}代码中的某处:if(x.y.z.a===true){//dosomething}在某些情况下,任何x、y、z变量都可能未定义,在这种情况下,您会得到“无法读取未定义的属性*”可能的解决方案是:if(x&&x.y&&x.y.z&&x.y.z.a===true){//dosomething}jsfiddle:http://jsfiddle.net/EcFLk/2/但是有没有更简单/更快捷的方法呢?内联解决方案(不使用特殊功能)会很棒。谢谢。 最佳答案 不,你

Javascript 在 If 语句中错误地执行 MVC 代码

我对下面的代码有点困惑。它在Windows7上的VS2010中运行良好,现在我已经将硬件升级到Windows8和VS2012,但它没有。我的MVC应用程序中有以下JavaScript代码:vartoday;if("@Model.Birthday.HasValue"){vartoday=newDate("@Model.Birthday.Value.Year","@Model.Birthday.Value.Month"-1,"@Model.Birthday.Value.Day");}else{today=newDate();}模型从具有如下属性的ViewModel拉取:publicSyst