1、原生js写法

!function () {
document.getElementById('bankCard').onkeyup = function (event) {
var v = this.value;
if(/\S{5}/.test(v)){
this.value = v.replace(/\s/g, '').replace(/(.{4})/g, "$1 ");
}
};
}();

2、jQuery写法

< !DOCTYPE html>











php的header来定义一个php页面为utf编码或GBK编码

php页面为utf编码
header("Content-type: text/html; charset=utf-8");

php页面为gbk编码
header("Content-type: text/html; charset=gb2312");

php页面为big5编码
header("Content-type: text/html; charset=big5");

通常情况以上代码放在php页面的首页

用header或meta实现PHP页面编码的区别
一、页面编码

1. 使用 标签设置页面编码

这个标签的作用是声明客户端的浏览器用什么字符集编码显示该页面,xxx可以为GB2312,GBK,UTF-8(和MySQL不同,MySQL是 UTF8)等等。因此,大部分页面可以采用这种方式来告诉浏览器显示这个页面的时候采用什么编码,这样才不会造成编码错误而产生乱码。但是有的时候我们会 发现有了这句还是不行,不管xxx是哪一种,浏览器采用的始终都是一种编码,这个情况我后面会谈到。

请注意,是属于html信息的,仅仅是一个声明,它起作用表明服务器已经把HTML信息传到了浏览器。

2. header(“content-type:text/html; charset=xxx”);

这个函数header()的作用是把括号里面的信息发到http标头。

如果括号里面的内容为文中所说那样,那作用和标签基本相同,大家对照第一个看发现字符都差不多的。但是不同的是如果有这段 函数,浏览器就会永远采用你所要求的xxx编码,绝对不会不听话,因此这个函数是很有用的。为什么会这样呢?那就得说说HTTPS标头和HTML信息的差 别了:

https标头是服务器以HTTP协议传送HTML信息到浏览器前所送出的字串。

因为meta标签是属于html信息的,所以header()发送的内容先到达浏览器,通俗点就是header()的优先级高于meta(不知道可 不可以这样讲)。加入一个php页面既有header(“content-type:text/html; charset=xxx”),又有,浏览器就只认前者http标头而不认meta了。当然这个函数只能在php页面内使用。

同样也留有一个问题,为什么前者就绝对起作用,而后者有时候就不行呢?这就是接下来要谈的Apache的原因了。

3. AddDefaultCharset

Apache 根目录的 conf 文件夹里,有整个Apache的配置文档httpd.conf。

用文本编辑器打开httpd.conf,第708行(不同版本可能不同)有AddDefaultCharset xxx,xxx为编码名称。这行代码的意思:设置整个服务器内的网页文件https标头里的字符集为你默认的xxx字符集。有这行,就相当于给每个文件都 加了一行header(“content-type:text/html; charset=xxx”)。这下就明白为什么明明meta设置了是utf-8,可浏览器始终采用gb2312的原因。

如果网页里有header(“content-type:text/html; charset=xxx”),就把默认的字符集改为你设置的字符集,所以这个函数永远有用。如果把AddDefaultCharset xxx前面加个“#”,注释掉这句,而且页面里不含header(“content-type…”),那这个时候就轮到meta标签起作用了。

总结:

来个排序

header(“content-type:text/html; charset=xxx”)
AddDefaultCharset xxx

如果你是web程序员,给你的每个页面都加个header(“content-type:text/html; charset=xxx”),保证它在任何服务器都能正确显示,可移植性强。

至于那句AddDefaultCharset xxx,要不要注释就仁者见仁了。反正我是注释掉了,不过我写页子也要写header(),便于放到服务器上能正常显示。

二、数据库编码

PHP 程序在查询数据库之前,首先执行 mysql_query(“SET NAMES xxxx”);其中 xxxx 是你网页的编码(charset=xxxx),如果网页中 charset=utf8,则 xxxx=utf8,如果网页中 charset=gb2312,则xxxx=gb2312,几乎所有WEB程序,都有一段连接数据库的公共代码,放在一个文件里,在这文件里,加入 mysql_query(“set names”)就可以了。

SET NAMES 显示客户端发送的 SQL 语句中使用什么字符集。因此,SET NAMES ‘utf-8’语句告诉服务器“将来从这个客户端传来的信息采用字符集utf-8”。它还为服务器发送回客户端的结果指定了字符集。(例如,如果你使用一 个SELECT语句,它表示列值使用了什么字符集。)

PHP页面编码统一

MySQL数据库编码、html页面编码、PHP或html文件本身编码要全部一致。
  1、MySQL数据库编码:建立数据库时指定编码(如gbk_chinese_ci),建立数据表、建立字段、插入数据时不要指定编码,会自动继承数据库的编码。
数据库连接时,也有编码,可以在连接完数据库后,执行
mysql_query(‘SET NAMES gbk’);//将gbk换成你的编码,如utf8。

  2、html页面的编码,指的是这一行的设置:

  3、PHP或html文件本身的编码:用editplus打开php文件或html文件,另存时,选择的编码,如果数据库和页面编码是gbk,则这儿的编码选择ansi;如果数据库和页面编码是utf-8,则这儿也选择utf-8。

  4、另外要注意的是,Javascript或Flash中传递的数据是utf-8编码,如果数据库和页面编码是gbk,要进行转码,然后写入数据库。
iconv(‘utf-8’, ‘gbk’, $content);

5、在PHP程序中,可以加上一行,来指定PHP源程序的编码:
header(‘Content-type: text/html; charset=gbk’);

近期,微软向全球的 Windows 8 和 Win 7 的用户推送了 Windows 10 免费升级的提示,用户电脑的任务栏右下角会出现一个提示图标,点击后会出现 Windows 10 免费升级版的相关介绍信息。

但目前来说,即便用户预订了 Win 10 的升级后,仍然需要等待通知。直到 Windows 10 正式发布后才会下载安装包并升级到 Windows 10 版本。

然而,微软宣布将于7月29日在全球推送 Windows 10 的升级,但目前这个升级提示的图标会始终“常驻”在任务栏右下角,无法关闭、删除或隐藏,因此很多人都感到非常不爽。下面我就介绍一个方法,可以关闭删除这个任务栏右下角的 Windows 10 升级提醒的推送图标。

打开控制面板,在“程序-卸载程序-查看已安装的更新”里面,找到“用于 Microsoft Windows 的安全更新(KB3035583)”,右键点击将其卸载,然后重启电脑,之后任务栏右下角的该图标就不见了。

如果下次 Windows 再提示安装这个KB3035583补丁,不必再安装,选中并将其忽略即可。

由于很多网友向我反应,这儿这个编译脚本不能成功编译iOS8的库,所以在空闲时间搞了一下, 让其支持iOS8与bitcode.

#!/bin/sh

set -xe

VERSION="0.1.3"
SDKVERSION="8.4"
LIBSRCNAME="opencore-amr"

CURRENTPATH=`pwd`

mkdir -p "${CURRENTPATH}/src"
tar zxvf ${LIBSRCNAME}-${VERSION}.tar.gz -C "${CURRENTPATH}/src"
cd "${CURRENTPATH}/src/${LIBSRCNAME}-${VERSION}"

DEVELOPER=`xcode-select -print-path`
DEST="${CURRENTPATH}/lib-ios"
mkdir -p "${DEST}"

ARCHS="armv7 armv7s arm64 i386 x86_64"
# ARCHS="armv7"
LIBS="libopencore-amrnb.a libopencore-amrwb.a"

DEVELOPER=`xcode-select -print-path`

for arch in $ARCHS; do
case $arch in
arm*)

IOSV="-miphoneos-version-min=7.0"
if [ $arch == "arm64" ]
then
IOSV="-miphoneos-version-min=7.0"
fi

echo "Building for iOS $arch ****************"
SDKROOT="$(xcrun --sdk iphoneos --show-sdk-path)"
CC="$(xcrun --sdk iphoneos -f clang)"
CXX="$(xcrun --sdk iphoneos -f clang++)"
CPP="$(xcrun -sdk iphonesimulator -f clang++)"
CFLAGS="-isysroot $SDKROOT -arch $arch $IOSV -isystem $SDKROOT/usr/include -fembed-bitcode"
CXXFLAGS=$CFLAGS
CPPFLAGS=$CFLAGS
export CC CXX CFLAGS CXXFLAGS CPPFLAGS

./configure \
--host=arm-apple-darwin \
--prefix=$DEST \
--disable-shared --enable-static
;;
*)
IOSV="-mios-simulator-version-min=7.0"
echo "Building for iOS $arch*****************"

SDKROOT=`xcodebuild -version -sdk iphonesimulator Path`
CC="$(xcrun -sdk iphoneos -f clang)"
CXX="$(xcrun -sdk iphonesimulator -f clang++)"
CPP="$(xcrun -sdk iphonesimulator -f clang++)"
CFLAGS="-isysroot $SDKROOT -arch $arch $IOSV -isystem $SDKROOT/usr/include -fembed-bitcode"
CXXFLAGS=$CFLAGS
CPPFLAGS=$CFLAGS
export CC CXX CFLAGS CXXFLAGS CPPFLAGS
./configure \
--prefix=$DEST \
--disable-shared
;;
esac
make > /dev/null
make install
make clean
for i in $LIBS; do
mv $DEST/lib/$i $DEST/lib/$i.$arch
done
done

for i in $LIBS; do
input=""
for arch in $ARCHS; do
input="$input $DEST/lib/$i.$arch"
done
lipo -create -output $DEST/lib/$i $input
done

//一个section刷新  
NSIndexSet *indexSet=[[NSIndexSet alloc]initWithIndex:2];  
[tableview reloadSections:indexSet withRowAnimation:UITableViewRowAnimationAutomatic];  
//一个cell刷新  
NSIndexPath *indexPath=[NSIndexPath indexPathForRow:3 inSection:0];  
[tableView reloadRowsAtIndexPaths:[NSArray arrayWithObjects:indexPath,nil] withRowAnimation:UITableViewRowAnimationNone];

相信在定义数据类型的时候可能会有类似的疑惑,CGFloat和float到底有什么区别,什么时候该用哪一种?

CGFloat is just a typedef for either float or double.
typedef float CGFloat;// 32-bit
typedef double CGFloat;// 64-bit

对于需要兼容64位机器的程序而言,需要用CGFloat,当然从长远角度考虑还是推荐尽量使用CGFloat。尽管在32位上相比float增加了一些memory footprint的消耗。

对应64位编程的时候,

对于整数应使用NSInteger和NSUInteger,而非int

对于小数应使用CGFloat,而非float

NSInteger其实是一个自动定义,在32位中为int,而64位中为long。

CGFloat的原理类似。

今天写了这么一小段测试代码,如下:

CGRect imageRect = (CGRect){100, 100, 100, 100};  
UIImageView *imageView = [[[UIImageView alloc] initWithFrame:imageRect] autorelease];  
imageView.backgroundColor = [UIColor yellowColor];  
[self.view addSubview:imageView];  
 
UIButton *maskBtn = [UIButton buttonWithType:UIButtonTypeCustom];  
maskBtn.frame = imageView.bounds;  
maskBtn.backgroundColor = [UIColor redColor];  
[maskBtn addTarget:self action:@selector(maskBtnDidClick:) forControlEvents:UIControlEventTouchUpInside];  
[imageView addSubview:maskBtn];  

结果点击按钮不响应事件,小纠结了一下,在SO上得到信息:

UIImageView has userInteractionEnabled set to NO by default. You are adding the button as a subview to the image view. You should set it to YES.

所以,添加了一行代码,设置imageView响应用户交互即可:

CGRect imageRect = (CGRect){100, 100, 100, 100};  
UIImageView *imageView = [[[UIImageView alloc] initWithFrame:imageRect] autorelease];  
imageView.backgroundColor = [UIColor yellowColor];  
[self.view addSubview:imageView];  
imageView.userInteractionEnabled = YES;  
 
UIButton *maskBtn = [UIButton buttonWithType:UIButtonTypeCustom];  
maskBtn.frame = imageView.bounds;  
maskBtn.backgroundColor = [UIColor redColor];  
[maskBtn addTarget:self action:@selector(maskBtnDidClick:) forControlEvents:UIControlEventTouchUpInside];  
[imageView addSubview:maskBtn];  

这纯粹就是一个知识点引发的坑,因为以前在UIImageView上都是使用TapGesture来响应用户交互的,所以对这个坑没有太大印象 —— 我遇到过没?

上面代码所构建的视图层级大致如下:

其中红色方框代表的是UIImageView上的UIButton按钮。

参考View Programming Guide for iOS文档,当用户在红色按钮上点击了一下后:

1. 硬件设施会通知UIKit有触摸事件;

2. UIKit将触摸事件信息封装成UIEvent对象,分发给合适的视图;

   1) UIKit将事件对象放到当前App的事件队列中;

   2) 参考Event Handling Guide for iOS文档,当前App会从事件队列取出一个事件对象,然后发送给key window对象;

   3) key window对象通过Hit-Testing获取触摸事件发生时所在的视图对象;

   4) 通过Hit-Testing获得的视图成为第一个可以响应事件的对象,first responder,如果它不响应,则事件对象会沿着响应者链传递。响应者链,即Responder Chain,是由first responder到当前App对象所构成的一串对象,它们都继承于UIResponder类;

P.S. 具体描述可以见此文档。

3. 找到合适的处理事件的对象,比如上面代码是self(ViewController),响应事件做些事情;如果找不到就丢弃掉。

今天项目中遇到个问题,在一个arraylist中删出指定的某些元素,开始想到的是用for循环,找到其中指定元素的下标,然后用remove(postion)方法将arraylist中的指定元素删除即可,最后发现会报错,因为用for循环删除指定元素的话,arraylist的下标是会改变的,会造成下标溢出的错误。

 那我们应该怎么做呢?下面我们用java里封装好的办法来处理这个问题。

 public static void removeListElement3(List< String> list) {
         Iterator<String> iterator = list.iterator();//参数填你的list存放的集合,这里是String,也可以是你自己定义的类
         while(iterator.hasNext()) {  //while循环
             String str = iterator.next();
             if("c".equals(str)) {   //如果取出的元素和你指定的值相等
                 iterator.remove();//从arraylist中删除该元素
             }
         }
   }

好了 ,这样我们就做到了删除arraylist指定的值

php 提取身份证号码中的生日日期以及确定是否成年的一个函数。可以同时确定15位和18位的身份证,

经本人亲测,非常好用,分享函数代码如下:

<?php
//用php从身份证中提取生日,包括15位和18位身份证
function getIDCardInfo($IDCard){
	$result['error']=0;//0:未知错误,1:身份证格式错误,2:无错误
	$result['flag']='';//0标示成年,1标示未成年
	$result['tdate']='';//生日,格式如:2012-11-15
	if(!eregi("^[1-9]([0-9a-zA-Z]{17}|[0-9a-zA-Z]{14})$",$IDCard)){
		$result['error']=1;
		return $result;
	}else{
		if(strlen($IDCard)==18){
			$tyear=intval(substr($IDCard,6,4));
			$tmonth=intval(substr($IDCard,10,2));
			$tday=intval(substr($IDCard,12,2));
			if($tyear>date("Y")||$tyear<(date("Y")-100)){
				$flag=0;
			}elseif($tmonth<0||$tmonth>12){
				$flag=0;
			}elseif($tday<0||$tday>31){
				$flag=0;
			}else{
				$tdate=$tyear."-".$tmonth."-".$tday." 00:00:00";
				if((time()-mktime(0,0,0,$tmonth,$tday,$tyear))>18*365*24*60*60){
					$flag=0;
				}else{
					$flag=1;
				}
			}
		}elseif(strlen($IDCard)==15){
			$tyear=intval("19".substr($IDCard,6,2));
			$tmonth=intval(substr($IDCard,8,2));
			$tday=intval(substr($IDCard,10,2));
			if($tyear>date("Y")||$tyear<(date("Y")-100)){
				$flag=0;
			}elseif($tmonth<0||$tmonth>12){
				$flag=0;
			}elseif($tday<0||$tday>31){
				$flag=0;
			}else{
				$tdate=$tyear."-".$tmonth."-".$tday." 00:00:00";
				if((time()-mktime(0,0,0,$tmonth,$tday,$tyear))>18*365*24*60*60){
					$flag=0;
				}else{
					$flag=1;
				}
			}
		}
	}
	$result['error']=2;//0:未知错误,1:身份证格式错误,2:无错误
	$result['isAdult']=$flag;//0标示成年,1标示未成年
	$result['birthday']=$tdate;//生日日期
	return $result;
}

用法:

getIDCardInfo('身份证号码');