javascript 函数初探 (二)--- 那些年的预定义函数
javascript的预定义函数:
javascript引擎中有一组可以随时调用的内建函数。
这些内建函数包括:
1. parseInt()
2. parseFloat()
3. isNaN()
4. isFinite()
5. encodeURI()
6. decodeURI()
7. encodeURIComponent()
8. decodeURIComponent()
9. eval()
=================>>>>>
黑盒函数
一般来说,当我们调用一个函数的时候,程序是不需要知道该函数的内部工作细节的。我们可以将其看作一个黑盒子,只需给他传递一些参数,便可以获取她输出返回的结果。
这种思维可以应用到任何函数中。
<<<<<=================
parseInt:
w3school解释是:parseInt() 函数可解析一个字符串,并返回一个整数。 即:parseInt(string, radix);
函数有两个调用方式
1、指定radix,这也是推荐的方式,很不幸我之前都不是这样做的
2、不指定radix,即:parseInt(string)。虽然简单,但规则很多,这也是本文阐述内容的核心。
parseInt(string, radix)
radix,表示转换的基数,也就是我们常说的2进制、8进制、10进制、16进制等。范围从2~36,但我们在JS中一般调用该方法时,基本都是以10为基数进行转换的。
如果该参数小于 2 或者大于 36,则 parseInt() 将返回 NaN。
“string”参数应用的详细规则如下:
1)如果都是字母,返回:NaN,例:
window.onload = function testParse() {
alert(parseInt());
}
2)如果都不是字母,返回:123,例:
window.onload = function testParse() {
alert(parseInt());
}
3)如果字母和数字都存在,例:
window.onload = function testParse() {
alert(parseInt());
alert(parseInt()); // NaN
}
这里涉及到两个规则:
1)如果参数“string”,以数字开头,则取截止到第一个字母出现之前的所有数字进行转换.上例中,第一个出现的字母是‘x’,取之前的数字串,只有一个数字'1',结果就返回1
2)如果参数“string”,以字母开头,直接返回NaN.
以上描述按照ECMAScript的解释(官方翻译,很给力):
parseInt() 方法首先查看位置 0 处的字符,判断它是否是个有效数字;如果不是,该方法将返回 NaN,不再继续执行其他操作。但如果该字符是有效数字,该方法将查看位置 1 处的字符,进行同样的测试。这一过程将持续到发现非有效数字的字符为止,此时 parseInt() 将把该字符之前的字符串转换成数字。
parseFloat
parseFloat() 函数可解析一个字符串,并返回一个浮点数。
该函数指定字符串中的首个字符是否是数字。如果是,则对字符串进行解析,直到到达数字的末端为止,然后以数字返回该数字,而不是作为字符串。
语法:parseFloat(string);也就是说默认是十进制的,其他的基本同上述是一样的
提示和注释
注意: 字符串中只返回第一个数字。
注意: 开头和结尾的空格是允许的。
注意: 果字符串的第一个字符不能被转换为数字,那么 parseFloat() 会返回 NaN。
isNaN
通过isNaN(),我们可以确定某个输入值是否是一个可以参与算术运算的数字。因而可以检测parseInt(),parseFloat()的调用是否成功。
isNaN(NaN) // true
isNaN() // false
isNaN(1.45) // false
isNaN('abc123') // true
该函数也会试图将其接受的参数转化为数字
isNaN(') // false
isNaN('abc123') // true
NaN === NaN // false
isFinite
isFinite()可以检测输入是否是一个即非Infinity也非NaN的数字。
isFinite(InFinity) // false isFinite(-Infinity) // false isFinite() // true isFinite(1e309) // false
javascript 编码问题
本地 / Unicode
你可能对“本地”有点迷惑。刚开始,我也不理解,应该是编码之间转换才对。因为本地字符有编码,那么把这个编码转换成 Unicode 编码的说法很合理。其实,所有国家字符的 Unicode 编码都是确定的,无论是你输入的是哪国语。
Unicode 十进制和十六进制编码分别为:
例子lizi
例子lizi
本地到 Unicode 转换的 JavaScript 代码如下所示:
function nativeToUnicode(str) {
var des = [];
; i < str.length; i++)
des.push("&#" + str.charCodeAt(i) + ";");
//des.push("&#x" + str.charCodeAt(i).toString(16) + ";");
return des.join("");
}
Unicode 到本地转换的 JavaScript 代码如下所示:
function unicodeToNative(str) {
var src = str.match(/&#(\d+);/g);
if (src != null) {
var des = [];
; i < src.length; i++)
des.push(String.fromCharCode(src[i].replace(/[&#;]/g, "")));
return des.join("");
}
return "";
}
说明:
- String.charCodeAt() 方法可返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数。
- String.fromCharCode() 方法可接受一个指定的 Unicode 值,然后返回一个字符串。
本地 / UTF-8
UTF-8 是 Unicode 的实现方式之一,把定长编码改成变长的,减少了存储和传输的开销。从下面示例可以看到,中文是编码,而对用一个字节就能表示的英文字符,没有变化。
UTF-8 编码为:
例[
本地转换 UTF-8 的 JavaScript 代码如下所示:
function navtiveToUTF8(str) {
) { ).replace(/(%u)(\w{})/gi, "&#x$2;") });
}
UTF-8 转换本地的 JavaScript 代码如下所示:
function utfToNative(str) {
return unescape(str.replace(/&#x/g, '%u').replace(/;/g, ''));
}
说明:
- escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串。
- unescape() 函数可对通过 escape() 编码的字符串进行解码。
本地 / ASCII
ASCII 码转换或不转换 ASCII 的编码为:
\u4f8b\u5b50lizi
\u4f8b\u5b50\u006c\u0069\u007a\u0069
本地转换 ASCII 的 JavaScript 代码如下所示:
function nativeToASCII(str, isIgnoreLetter) {
var character = str.split("");
var ascii = [];
; i < character.length; i++) {
));
) {
);
charAscii = ) + charAscii;
ascii.push("\\u" + charAscii);
}
else {
ascii.push(character[i]);
}
}
return ascii.join("");
}
ASCII 转换本地的 JavaScript 代码如下所示:
function asciiToNative(str) {
var character = str.split("\\u");
];
; i < character.length; i++) {
var code = character[i];
res += String.fromCharCode(parseInt(, )));
) {
res += code.substring(, code.length);
}
}
return res;
}
本地 / URI 编码
URI 编码不用以上编码,它的主要是出于安全性考虑,让链接的内容不能一目了然地看到是什么,防止恶意的偷看者。下面是 cnblogs 的“找找看”检索链接,对其进行编码。
示例 4:
http://zzk.cnblogs.com/s?w=例子lizi&t=
URI 编码和组件编码分别为:
http://zzk.cnblogs.com/s?w=%E4%BE%8B%E5%AD%90lizi&t=
http%3A%2F%2Fzzk.cnblogs.com%2Fs%3Fw%3D%E4%BE%8B%E5%AD%90lizi%26t%3D
说明:
- encodeURI() 函数可把字符串作为 URI 进行编码。
- decodeURI() 函数可对 encodeURI() 函数编码过的 URI 进行解码。
- encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。
- decodeURIComponent() 函数可对 encodeURIComponent() 函数编码的 URI 进行解码。
eval()函数请见下一篇 (。・_・)/~~~
详情请见==============》》》 http://www.cnblogs.com/liuning8023/archive/2012/12/09/2810518.html
javascript 函数初探 (二)--- 那些年的预定义函数的更多相关文章
- Java8学习笔记(二)--三个预定义函数接口
三个函数接口概述 JDK预定义了很多函数接口以避免用户重复定义.最典型的是Function: @FunctionalInterface public interface Function<T, ...
- PHP-自定义数组-预定义数组-自定义函数-预定义函数
(1)自定义数组 —— 项目中的重点 (2)PHP预定义数组 —— 重点&难点 (3)自定义函数 —— 了解 (4)PHP预定义函数 —— 项目中的重点 1.自定义数组 数组:array,一个 ...
- STL算法设计理念 - 预定义函数对象
预定义函数对象基本概念:标准模板库STL提前定义了很多预定义函数对象 1)使用预定义函数对象: #include <iostream> #include <cstdio> #i ...
- C++STL 预定义函数对象和函数适配器
预定义函数对象和函数适配器 预定义函数对象基本概念:标准模板库STL提前定义了很多预定义函数对象,#include <functional> 必须包含. 1使用预定义函数对象: void ...
- Atitit.跨平台预定义函数 魔术方法 魔术函数 钩子函数 api兼容性草案 v2 q216 java c# php js.docx
Atitit.跨平台预定义函数 魔术方法 魔术函数 钩子函数 api兼容性草案 v2 q216 java c# php js.docx 1.1. 预定义函数 魔术方法 魔术函数是什么1 1.2. & ...
- javascript 函数初探 (一)--- 神马是函数
神马是函数? 所谓函数,本质上是一种代码的分组形式.我们可以通过这种形式赋予某组代码一个名字,以便与之后的调用.下面,我们来示范以下函数的声明: function sum(a, b){ var c = ...
- JavaScript内置的预定义函数
javascript引擎中有一组可供随时调用的内建函数.这些内建函数包括 parseInt() 将收到的任何输入值转换成整数类型输出,如果转换失败,返回NaN parseFloat() 功能基本与p ...
- javascript 预定义函数
parseInt() parseFloat() isNaN() isFinite() encodeURI() decodeURI() encodeURIComponent() decodeURICom ...
- 【摘录自MDN】预定义函数
JavaScript语言有好些个顶级的内建函数: eval() eval()方法会对一串字符串形式的JavaScript代码字符求值. uneval() uneval()方法创建的一个Object的 ...
随机推荐
- bootstrap-modal 学习笔记 源码分析
Bootstrap是Twitter推出的一个开源的用于前端开发的工具包,怎么用直接官网 http://twitter.github.io/bootstrap/ 我博客的定位就是把这些年看过的源码给慢慢 ...
- MySQL学习笔记十三:表分区
1.分区一般用于非常大的表,采用“分而治之”的策略,将一个很大的对象分成多个小对象进行管理,每个分区都是一个独立的对象. 分区使用分区键将数据根据范围值,特定列值或HASH值等规则分布在不同的分区中. ...
- iOS开发之SQLite--C语言接口规范(四) —— Result Values From A Query
数据库的在上一篇博客中<SQLite之C语言接口规范(三)——Binding Values To Prepared Statements>用到了如何从查询结果中取出结果值.今天的博客就详细 ...
- YII 的源码分析(二)
上一篇简单分析了一下yii的流程,从创建一个应用,到屏幕上输出结果.这一次我来一个稍复杂一点的,重点在输出上,不再是简单的一行"hello world",而是要经过view(视图) ...
- 设计数据库字段或者java中使用boolean型时需谨慎
boolean型变量只有两个值 false和true,我们在设计数据库字段时或者定义java变量时会使用boolean,通常情况下开关类的变量使用无可非议,但请一定要考虑到扩展性. 使用前请仔细考虑一 ...
- 软件开发常用设计模式—单例模式总结(c++版)
单例模式:就是只有一个实例. singleton pattern单例模式:确保某一个类在程序运行中只能生成一个实例,并提供一个访问它的全局访问点.这个类称为单例类.如一个工程中,数据库访问对象只有一个 ...
- 不要给<a>设置outline:none
outline属性有什么作用 原文链接 a{outline:none} do not do it 当用户使用tab键进行链接切换时,该属性会在当前选中的链接(获得焦点)使用该属性,一般来说是虚线框 的 ...
- CSS3实现图形曲线阴形和翘边阴影
首先,来看看完成之后的效果图: 实现原理 ①曲线阴影实现: 多个阴影重叠,就是正常阴影+曲线阴影 正常情况下,有个矩形有正常的阴影,作为主投影,这时候再定义一个有一定弧度圆角的圆角矩形,然后放在正常矩 ...
- spring整合hibernate的时候报异常org.hibernate.HibernateException: createQuery is not valid without active transaction
在整合Spring4+hibernate4时候,当代码执行到dao中CRUD操作时,报了一个异常, org.hibernate.HibernateException: createQuery is n ...
- 第一篇blog
之前不用blog,但是在杭电oj,poj上刷题,总会自己总结题型和使用什么算法,算法模板,自己在笔记本上写,耗时费力,感觉用键盘敲得总结,分享,大家相互学习提高.有时遇到不会做的,或者总是在oj上跑的 ...