/** * 大数与或操作 */ global.andorOpera = function (a, b, type) { //type = 1是与运算,type = 2 是或运算,默认是与运算 a...= longer.length - sorter.length; for (var i = longer.length - 1; i >= 0; i--) { if (type == 2) { //或运算...1 : 0; } else { //与运算 _tstr += longer[i] == 1 && sorter[i - _fix] == 1 ?
也就是说,运算子的不同,导致了不同的语法行为,这种现象称为“重载”(overload) (1)、在两个操作数都是数字的时候,会做加法运算 console.log(2+4);//6 (2)、两个参数都是字符串或在有一个参数是字符串的情况下...,会把另外一个参数转换为字符串做字符串拼接 console.log("2"+"4");//"24" '3' + 4 + 5 // "345" 3 + 4 + '5' // "75" (3)、在参数有对象的情况下...3.1首先自动调用对象的valueOf方法 一般来说,对象的valueOf方法总是返回对象自身,,也可自定义 3.2再自动调用对象的toString方法,将其转为字符串(如果valueOf方法直接返回一个原始类型的值...5、其他比较运算符( 大于 >= 大于或等于) 5.1同为字符串按照Unicode 顺序进行比较 首先比较首字符的 Unicode 码点,如果相等,再比较第二个字符的 Unicode...码点,以此类推 5.2不全为字符串的比较,分成以下两种情况 1)原始类型值(数值、字符串、布尔值) 如果两个运算子都是原始类型的值,则是先转成数值再比较 5 > '4' // true // 等同于
//第二种 var timestamp = new Date().getTime(); //第三种 var timestamp = new Date().valueOf(); //第四种,通过运算...new Date() * 1; //new Date()-0 ,new Date()/1 //第五种 ,通过转换 var timestamp = Date.parse(new Date()); 时间戳的运算
前言:今天的内容是对js的部分基础内容过一遍,没有细细的去分析,只是一篇概要。...好比吃火锅,边吃边涮,同时进行 标识符,关键字,保留字 (一)标识符 标识符:就是指开发人员为变量,属性,函数,参数取的名字(自定义) 注意:标识符:不能是关键字或者保留字 (二)关键字 关键字:是指JS...运算符 运算符:也被称为操作符,是用于实现赋值,比较和执行算数运算等功能的符号。...js中常用的运算符有 算数运算符 递增和递减运算符 比较运算符 逻辑运算符 赋值运算符 算术运算符 概念:算术运算使用的符号,用于执行两个变量或值的算术运算。...=== 全等 判断两边的值和数据类型是否完全相同 代码演示 console.log(3>=5); console.log(2<=4); //1.我们程序里的等于符号,是默认转换类型,会把字符串的数据类型转换为数字型只要求值相等就可以了
都知道拿js去做运算肯定会遇到计算精准的问题(或称舍入误差),但是怎么避开这些坑,这里是我从网上整理的方案,欢迎探讨。 ?...0.0001 1001 1001 1001…(1001无限循环) 0.2 >> 0.0011 0011 0011 0011…(0011无限循环) 解决方案 如需要更加复杂的计算类库,可以考虑 math.js...= 0.3 // true 浮点精准运算 /** * floatObj 包含加减乘除四个方法,能确保浮点数运算不丢失精度 * * ** method ** * add / subtract /...,确保不丢失精度 * 思路:把小数放大为整数(乘),进行算术运算,再缩小为小数(除) * * @param a {number} 运算数1 * @param b...result.shift(); } result = s + result.join(''); } return result; } 使用方法:不可使用负数,参数最好使用字符串
整理js中可以用到的判断一个字符串中是否包含另外一个字符的方法 String对象方法 1、indexOf indexOf 返回指定字符串在该字符中首次出现的位置,如果没有找到,则返回 -1 indexOf...'a',2));// -1 console.log(str.indexOf('a'))// 0 2、lastIndexOf lastIndexOf是从字符串末尾开始搜索,返回指定字符串在该字符中最后一次出现的位置...console.log(str.lastIndexOf('a',2));// 0 console.log(str.lastIndexOf('a'));// 5 3、includes includes() 方法用于判断字符串是否包含指定的子字符串...);//['a','a','a'] console.log(str.match(/z/gi));// null 5、 search seacrh方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串...如果字符串中有匹配的值返回该匹配值,否则返回 null。
移位运算符是C++中常用的算术表达式 但是在前端和硬件通过蓝牙通信时我们也会经常用到 移位运算符在程序设计中,是位操作运算符的一种。...移位运算符可以在二进制的基础上对数字进行平移。...按照平移的方向和填充数字的规则分为三种: << //左移 >> //带符号右移 >>> //无符号右移 左移运算符(<<)规则 按二进制形式把所有的数字向左移动对应的位数,高位移出...1<<3 //等于 1*2³ 8 2<<3 //等于 2*2³ 16 右移运算符(>>)规则: 按二进制形式把所有的数字向右移动对应位移位数,低位移出(舍弃),高位的空位补符号位,即正数补零...10>>3 //等于 1 100>>3 //等于 12 无符号右移运算符规则: 按二进制形式把所有的数字向右移动对应位数,低位移出(舍弃),高位的空位补零。
自己写了一波解决方法(不能单纯的乘Math.pow(10,N)变成整数运算完再除掉,因为乘也会有精度问题,就像题面19.99*100不等于1999。)...return parseInt(n1)*parseInt(n2)/Math.pow(10,c1+c2); } console.log(formatFloat(19.99,100)); 这里把小数变整数的方法是用字符串方法去掉小数点...然后上网一查,自己的方法其实早就有啦,而且网上的更全面,所以摘抄下来一个备用: /** * 加法运算,避免数据相加小数点后产生多位数和计算精度损失。..., Math.max(baseNum1, baseNum2)); return (num1 * baseNum + num2 * baseNum) / baseNum; }; /** * 加法运算...", "")) / Math.pow(10, baseNum); }; /** * 除法运算,避免数据相除小数点后产生多位数和计算精度损失。
js 字符串转数组: var string =”20170524191718-173910&135562983280&1″; var str =string.split(“&”); console.log...(str); 结果显示: console.log(str[2]);//1 js 字符串截取: var filename = (“#”+fileid).val().substring((“#”+fileid
下表实例变量 a 值为字符串 "Hello",b 变量值为 "Python": 操作符 描述 实例 + 字符串连接 >>>a + b 'HelloPython' * 重复输出字符串 >>>a * 2 '...HelloHello' [] 通过索引获取字符串中字符 >>>a[1] 'e' [ : ] 截取字符串中的一部分 >>>a[1:4] 'ell' in 成员运算符 - 如果字符串中包含给定的字符返回 True...>>>"H" in a True not in 成员运算符 - 如果字符串中不包含给定的字符返回 True >>>"M" not in a True r/R 原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思来使用...原始字符串除在字符串的第一个引号前加上字母"r"(可以大小写)以外,与普通字符串有着几乎完全相同的语法。...>>>print r'\n' \n >>> print R'\n' \n % 格式字符串 请看下一章节 实例(Python 2.0+) #!
下表列出了常用的字符串运算符,假定变量 a 为 “abc”,变量 b 为 “efg”: 运算符 说明 举例 = 检测两个字符串是否相等,相等返回 true。...= 检测两个字符串是否不相等,不相等返回 true。 [ $a != $b ] 返回 true。 -z 检测字符串长度是否为0,为0返回 true。 [ -z $a ] 返回 false。...字符串运算符实例如下: #!..."$a : 字符串不为空" else echo "$a : 字符串为空" fi 执行脚本,输出结果如下所示: abc = efg: a 不等于 b abc !...= efg : a 不等于 b -z abc : 字符串长度不为 0 -n abc : 字符串长度不为 0 abc : 字符串不为空
js三目运算符 js三目运算符的正常表达为 variable = boolean_expression ?...ToBoolean方法返回值如下: 参考链接: http://lzw.me/pages/ecmascript/#209 http://www.w3school.com.cn/js/pro_js_operators_boolean.asp
最近要做数据处理,自定义了一些数据结构,比如Mat,Vector,Point之类的,对于加减乘除之类的四则运算还要重复定义,代码显得不是很直观,javascript没有运算符重载这个像C++、C#之类的功能的确令人不爽...,于是想“曲线救国”,自动将翻译代码实现运算符重载,实现思路其实很简单,就是编写一个解释器,将代码编译。...isPrototypeOf(b) && Object.getPrototypeOf(b).isPrototypeOf(a)){ throw '不同类型的对象不能使用四则运算...大学学习数据结构时四则运算的实现就是这翻译的基础,略微有些差异。...简单描述一下流程: 1、分割表达式,提取变量和运算符获得元数组A 2、遍历元数组 如果元素是运算符加减乘除,则从堆栈中弹出上一个元素,转换为replace(last,操作符, 如果元素是‘)’,则从堆栈中弹出元素
我是想在js中判断字符串是否包含某个中文,将方法记录起来,这些方法也适用于数字、字母。实践是检验真理的唯一标准,还是要多多测试啊。...= -1)); //true indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。如果要检索的字符串值没有出现,则该方法返回 -1。...= -1)); //true search() 方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。如果没有找到任何匹配的子串,则返回 -1。..."; var reg = RegExp(/组/); alert('groupName.match(reg)=' + (groupName.match(reg))); //组 match() 方法可在字符串内检索指定的值...但你有木有发现打印出来的是 ‘ 组 ’ ,如果是在字符串中找不到的话打印 null ,神奇的是可以把它放在 if 里面做判断,如下: var str="123"; var reg3 = RegExp(/
new运算符 在JavaScript中,new是一个语法糖,可以简化代码的编写,可以批量创建对象实例。...stuGroup = []; for(let i=0;i<10;++i){ stuGroup.push(new Student(i)); } console.log(stuGroup); new运算符的操作
说来惭愧,JS基本的与或运算都没掌握完全,下面说一下与或运算的结果 1.与运算(&&) 与运算有可能返回五种结果,true、false、null、NaN、undefined 运算规则如下 1.与运算所有项为...= 'www'; let c = false; let d = true; a && b; //www a && b && c; //true c && a; //11 2.与运算有...false包括(0、false、null、NaN、undefined) null && false; //null false && null; //false NaN && null; //NaN 2.或运算...(||) 或运算同样可能返回五种结果,true、false、null、NaN、undefined 1.有一项不为false时返回第一个不为false的值 NaN || 1; //1 'str' ||...false、null、NaN、undefined) null || false; //false false || null; //null NaN || null || 0; //0 以上是与或运算的规则
逻辑运算符 在 js 中,我们都知道有逻辑运算符,比如 逻辑与 ( && )、逻辑或( || )、逻辑非( ! )、空值合并运算符(??)...然而,|| 运算符实际上是返回一个指定的操作数的值,所以如果这个运算符被用于非布尔值,它将返回一个非布尔值。...空值合并运算符(??)是一个逻辑运算符,当左侧的操作数为 null 或者 undefined 时,返回其右侧操作数,否则返回左侧操作数。...逻辑赋值 就是在逻辑运算符的情况下+赋值比如 a&&=2,就是 a=a&&2 逻辑空赋值(??=) 逻辑空赋值运算符(x ??...) ,其他都是两个连续相等的运算符表示,单个运算符表示的都是按位运算符,不要搞混。
; document.write(str.charAt(1); 2、获取字符串中所有数字。 <!...符号的位置 console.log(str.substring(str.length,str.length-1)); //@,截取最后一位数 //获取字符串中的所有数字跟...return newArr; } var newArr2= new deRepeat(arr); alert(newArr2); //输出1,2,3,4,5,6,9,25*/ 5、截取字符串
运算符优先级 从高到低的顺序: ^ not - (unary) * / + - .. = ~= == and or...eg: -- 运算符优先级 print( 2+3 * 2 ^ 2 .."!")...字符串 string.gsub(mainString,findString,replaceString,num) 在字符串中替换,mainString为要替换的字符串, findString 为被替换的字符...回一个迭代器函数,每一次调用这个函数,返回一个在字符串 str 找到的下一个符合 pattern 描述的子串。...如果参数 pattern 描述的字符串没有找到,迭代函数返回nil。
翻转字符串 // reversevar name = "My city is WH"; var resultStr = name.split
领取专属 10元无门槛券
手把手带您无忧上云