常用简易JavaScript函数


Posted in Javascript onApril 09, 2009

//函数名:strByteLength
//功能介绍:返回字符串的字节长度
//参数说明:str 要检查的字符串
//返回值:字符串长度
function strByteLength(str)
{
var i,sum;
sum=0;
for(i=0;i<str.length;i++)
{
if ((str.charCodeAt(i)>=0) & (str.charCodeAt(i)<=255))
sum=sum+1;
else
sum=sum+2;
}
return sum;
}
//函数名:fucCheckLength
//功能介绍:检查表单是否符合规定的长度
//参数说明:obj 要检查的表单对象
// name 对象名称
// length 规定长度
//返回值:true(符合) or false(不符)
function fucCheckLength(obj , name , length)
{
var i,sum;
sum=0;
var strTemp = obj.value;
for(i=0;i<strTemp.length;i++)
{
if ((strTemp.charCodeAt(i)>=0) & (strTemp.charCodeAt(i)<=255))
sum=sum+1;
else
sum=sum+2;
}
if(sum<=length)
{
return true;
}
else
{
alert(name+"超出规定长度!最长允许"+length+"个字符(中文算2位)!");
obj.focus();
return false;
}
}
//检测电子邮件是否合法
function checkEmail(Object)
{
var pattern = /^[.-_A-Za-z0-9]+@([-_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/;
var strValue=Object.value;
if(strValue.match(pattern)==null){
alert("Email不合法,请重新填写!");
Object.focus();
return false;
}else{
return true;
}
}
//去空隔函数
function Jtrim(str){
var i = 0;
var len = str.length;
if ( str == "" ) return( str );
j = len -1;
flagbegin = true;
flagend = true;
while ( flagbegin == true & i< len){
if ( str.charAt(i) == " " ){
i=i+1;
flagbegin=true;
}else{
flagbegin=false;
}
}
while (flagend== true & j>=0){
if (str.charAt(j)==" "){
j=j-1;
flagend=true;
}else{
flagend=false;
}
}
if ( i > j ) return ("")
trimstr = str.substring(i,j+1);
return trimstr;
}
//函数名:JtrimCn
//功能介绍:去掉字符串前后的空格[包括中文空格]
//参数说明:str 要操作的字符串
//返回值:删除了前后空格[包括中文空格]的字符串
function JtrimCn(str){
var i = 0;
if (str == null || str == undefined) {
return "";
}
var len = str.length;
if ( str == "" ) {
return( str );
}
j = len -1;
flagbegin = true;
flagend = true;
while ( flagbegin == true & i< len){
if ( str.charAt(i) == " " || str.charAt(i) == " " ){
i=i+1;
flagbegin=true;
}else{
flagbegin=false;
}
}
while (flagend== true & j>=0){
if (str.charAt(j)==" " || str.charAt(j) == " "){
j=j-1;
flagend=true;
}else{
flagend=false;
}
}
if ( i > j ) {
return ("")
}
var trimstr = str.substring(i,j+1);
return trimstr;
}
//0-9,A-Z,a-z规范字符判断
function isChar(Str){
var regu = "^([0-9a-zA-Z]+)$";
var re = new RegExp(regu);
if (Str.search(re) != -1){
return true;
}
return false;
}
//判断是否数字
function IsNum(Str){
var regu = "^([0-9]+)$";
var re = new RegExp(regu);
if (Str.search(re) != -1)
return true;
{
return false;
}
}
//函数名:funcIsNotEmpty
//功能介绍:检查字符串是否为空
//参数说明:str 字符串
//返回值:true:不为空 false:为空
function funcIsNotEmpty(str){
var s = /\S/;
if(str==null){
return false;
}
return s.test(str);
}
//函数名:fucCheckLength
//功能介绍:检查表单是否符合规定的长度
//参数说明:objValue 要检查的表单对象的数值
// name 对象名称
// minLen 最小长度
// maxLen 最大长度
//返回值:true(符合) or false(不符)
function fucCheckLengthB(objValue , minLen , maxLen)
{
var i,sum;
sum=0;
var strTemp = objValue;
for(i=0;i<strTemp.length;i++)
{
if ((strTemp.charCodeAt(i)>=0) & (strTemp.charCodeAt(i)<=255))
sum=sum+1;
else
sum=sum+2;
}
if(sum<=maxLen & sum >= minLen)
{
return true;
}
else
{
return false;
}
}
//sDate1和sDate2是2002-12-18格式
function funDateDiff(sDate1, sDate2){
var aDate, oDate1, oDate2, iDays ;
aDate = sDate1.split("-") ;
//转换为12-18-2002格式
oDate1 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0]);
aDate = sDate2.split("-") ;
oDate2 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0]) ;
//把相差的毫秒数转换为天数
iDays = parseInt(Math.abs(oDate1 - oDate2) / 1000 / 60 / 60 /24);
//如果开始时间小于结束时间
if (sDate1 > sDate2)
{
return (-1 * iDays);
}
return iDays;
}
//检测电子邮件是否合法
function funcCheckEmail(strValue)
{
var pattern = /^[.-_A-Za-z0-9]+@([-_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/;
if(strValue.match(pattern)==null){
return false;
}else{
return true;
}
}
//函数名:fucCheckMaxLength
//功能介绍:检查表单是否符合规定的长度
//参数说明:objValue 要检查的表单对象的数值
// name 对象数值
// maxLen 最大长度
//返回值:true(符合) or false(不符)
function fucCheckMaxLength(objValue , maxLen)
{
return fucCheckLengthB(objValue, 0 ,maxLen );
}
//函数名:fucCheckMaxLength
//功能介绍:检查指定对象的数值是否符合规定的长度
//参数说明:objValue 要检查的表单对象的数值
// name 对象
// maxLen 最大长度
//返回值:true(符合) or false(不符)
function fucCheckObjMaxLength(obj , maxLen)
{
if (obj == null) {
return false;
}
return fucCheckLengthB(obj.value, 0 ,maxLen );
}
//函数名:funcCheckInvalidChar
//功能介绍:判断指定的字段是否有非法字符<>
//参数说明:obj 要检查的表单对象
//返回值:true(没有) or false(有)
function funcCheckInvalidChar(obj)
{
if (obj == null || obj.value== "")
{
return true;
}
//alert(obj.value);
var pattern = /[<>]/;
if(pattern.test(obj.value)){
return false;
}else{
return true;
}
}
/**
* 判断指定的ID的对象的最大长度是否正确
* param: objId 对象ID
* maxLength 最大长度
* return: true 正确 , false 不正确
*/
function lengthMaxCheckMsg(objId, maxLength, objName ,needFocus, showMsg) {
//个人信息check
var obj = document.getElementById(objId);
if (!fucCheckObjMaxLength(obj, maxLength)) {
if (showMsg == null || showMsg== "") {
alert(objName + "最多只能输入" + (maxLength/2) + "个汉字(或" + maxLength + "个英文数字)");
} else {
alert(showMsg);
}
if (needFocus) {
obj.focus();
}
return false;
}
return true;
}
/**
* 判断指定的ID的对象的是否包含非法字符
* param: objId 对象ID
* objName 对象的名称
* needFocus 是否需要设焦点
* showMsg 显示的错误消息
* return: true 正确 , false 不正确
*/
function invalidCharCheckMsg(objId, objName,needFocus, showMsg) {
//个人信息check
var obj = document.getElementById(objId);
if (!funcCheckInvalidChar(obj)) {
if (showMsg == null || showMsg== "") {
alert(objName + '中不能含有“<”或“>”');
} else {
alert(showMsg);
}
if (needFocus) {
obj.focus();
}
return false;
}
return true;
}
/**
* 判断指定的ID的对象是否为空
* param: objId 对象ID
* objName 对象的名称
* needFocus 是否需要设焦点
* showMsg 显示的错误消息
* return: true 不为空 , false 为空
*/
function emptyCheckMsg(objId, objName,needFocus, showMsg) {
//个人信息check
var obj = document.getElementById(objId);
if (!funcIsNotEmpty(obj.value)) {
if (showMsg == null || showMsg== "") {
alert(objName + '不能为空!');
} else {
alert(showMsg);
}
if (needFocus) {
obj.focus();
}
return false;
}
return true;
}
/*日期计算函数
* date 2007-01-01
* cnt 1 or -1
* return 2007-01-02
*/
function getDate(date , cnt){
if(date.length!=10){
return "";
}
var dateArray = date.split("-")
if(dateArray==null){
return "";
}
var temDate = new Date(dateArray[0], dateArray[1]-1, dateArray[2]);
var newDate = Date.UTC(temDate.getYear(),temDate.getMonth(),temDate.getDate())
newDate = newDate + (cnt*24*60*60*1000);
newDate = new Date(newDate);
var month = newDate.getMonth()+1;
var day = newDate.getDate();
if(Number(month)<10)
month = "0"+month;
if(Number(day)<10)
day = "0"+day;
var retDate = newDate.getYear() + "-" + month + "-" + day;
return retDate;
}

Javascript 相关文章推荐
[全兼容哦]--实用、简洁、炫酷的页面转入效果loing
May 07 Javascript
js 固定悬浮效果实现思路代码
Aug 02 Javascript
window.print打印指定div指定网页指定区域的方法
Aug 04 Javascript
jQuery控制cookie过期时间的方法
Apr 07 Javascript
深入探寻seajs的模块化与加载方式
Apr 14 Javascript
总结几道关于Node.js的面试问题
Jan 11 Javascript
Canvas实现微信红包照片效果
Aug 21 Javascript
require.js 加载过程与使用方法介绍
Oct 30 Javascript
nvm、nrm、npm 安装和使用详解(小结)
Jan 17 Javascript
javascript中如何判断类型汇总
May 14 Javascript
Node.js学习之内置模块fs用法示例
Jan 22 Javascript
详解JavaScript之ES5的继承
Jul 08 Javascript
javascript fullscreen全屏实现代码
Apr 09 #Javascript
jQuery 插件 将this下的div轮番显示
Apr 09 #Javascript
javascript RadioButtonList获取选中值
Apr 09 #Javascript
Cookie 注入是怎样产生的
Apr 08 #Javascript
javascript 表格排序和表头浮动效果(扩展SortTable)
Apr 07 #Javascript
javascript 放大镜效果js组件 qsoft.PopBigImage.v0.35 加入了chrome支持
Apr 07 #Javascript
javascript 日历提醒系统( 兼容所有浏览器 )
Apr 07 #Javascript
You might like
PHP开发不能违背的安全规则 过滤用户输入
2011/05/01 PHP
PHP 获取文件路径(灵活应用__FILE__)
2013/02/15 PHP
php实现memcache缓存示例讲解
2013/12/04 PHP
PHP错误和异长常处理总结
2014/03/06 PHP
JavaScript中void(0)的具体含义解释
2007/02/27 Javascript
jquery增加时编辑jqGrid(实例代码)
2013/11/08 Javascript
Javascript字符串对象的常用方法简明版
2014/06/26 Javascript
JavaScript实现twitter puddles算法实例
2014/12/06 Javascript
javascript进行四舍五入方法汇总
2014/12/16 Javascript
jquery实现平滑的二级下拉菜单效果
2015/08/26 Javascript
Jquery实现select multiple左右添加和删除功能的简单实例
2016/05/26 Javascript
JavaScript在控件上添加倒计时功能的实现代码
2017/07/04 Javascript
node.js基于express使用websocket的方法
2017/11/09 Javascript
解决vue中使用Axios调用接口时出现的ie数据处理问题
2018/08/13 Javascript
深入理解与使用keep-alive(配合router-view缓存整个路由页面)
2018/09/25 Javascript
node app 打包工具pkg的具体使用
2019/01/17 Javascript
layui form表单提交后实现自动刷新
2019/10/25 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
2020/03/04 Javascript
VUE中setTimeout和setInterval自动销毁案例
2020/09/07 Javascript
python按照多个字符对字符串进行分割的方法
2015/03/17 Python
Python编程之多态用法实例详解
2015/05/19 Python
巧用python和libnmapd,提取Nmap扫描结果
2016/08/23 Python
python 读取.csv文件数据到数组(矩阵)的实例讲解
2018/06/14 Python
Opencv-Python图像透视变换cv2.warpPerspective的示例
2019/04/11 Python
解决在pycharm运行代码,调用CMD窗口的命令运行显示乱码问题
2019/08/23 Python
英国国家美术馆商店:National Gallery
2019/05/01 全球购物
Ariat英国官网:为世界顶级马术运动员制造最优质的鞋类和服装
2020/02/14 全球购物
秘书岗位职责
2013/11/18 职场文书
工厂厂长的职责
2013/12/12 职场文书
我的大学生活职业生涯规划
2014/01/02 职场文书
给校长的建议书
2014/03/12 职场文书
基层党员对照检查材料
2014/08/25 职场文书
担保书怎么写 ?
2019/04/22 职场文书
详解CSS开发过程中的20个快速提升技巧
2021/05/21 HTML / CSS
如何在Python项目中引入日志
2021/05/31 Python
Mysql数据库按时间点恢复实战记录
2021/06/30 MySQL