alert($(window).height()); //浏览器时下窗口可视区域高度
alert($(document).height()); //浏览器时下窗口文档的高度
alert($(document.body).height());//浏览器时下窗口文档body的高度
alert($(document.body).outerHeight(true));//浏览器时下窗口文档body的总高度 包括border padding margin
alert($(window).width()); //浏览器时下窗口可视区域宽度
alert($(document).width());//浏览器时下窗口文档对于象宽度
alert($(document.body).width());//浏览器时下窗口文档body的高度
alert($(document.body).outerWidth(true));//浏览器时下窗口文档body的总宽度 包括border padding margin
alert($(document).scrollTop()); //获取滚动条到顶部的垂直高度
alert($(document).scrollLeft()); //获取滚动条到左边的垂直宽度
Category Archives: keyboard’s joy
MYSQL使用小记之IN查询排序与正则使用
IN查询排序:
select * from test where id in(3,1,5) order by find_in_set(id,’3,1,5′);
select * from test where id in(3,1,5) order by substring_index(’3,1,2′,id,1);
正则使用:
SELECT COUNT(alarmID)
FROM Alarm
WHERE (CVE NOT RLIKE ‘^CVE-[0-9]{4}-[0-9]{4}$’ OR CVE IS NULL)
jquery.validate remote 和 自定义验证方法[转]
$(function(){
var validator = $(“#enterRegForm”).validate({
debug:false, //调试模式取消submit的默认提交功能
//errorClass: “error”,//默认为错误的样式类为:error
//validClass: “check”,//验证成功后的样式,默认字符串valid
focusInvalid: true,//表单提交时,焦点会指向第一个没有通过验证的域
//focusCleanup:true;//焦点指向错误域时,隐藏错误信息,不可与focusInvalid一起使用!
onkeyup: true,
errorElement: “div”,
submitHandler: function(form){ //表单提交句柄,为一回调函数,带一个参数:form
form.submit(); //提交表单
},
HTML5 INPUT新增属性
|
HTML5的input标签新增了很多属性,也是让大家非常兴奋的一件事,用简单的一个属性搞定以前复杂的JS验证。input新增的这些属性,使得html和js的分工更明确了,使用起来十分舒畅。 我们先看下input新增了的属性: 新增属性一:autoconmplete autoconmplete可以赋值为 on 或者 off。当为 on的时候,浏览器能自动存储用户输入的内容。当用户返回到曾经填写过值的页面的时候,浏览器能把用户写过的值自动填写在相应的input框里。 现在很多网站都实现了这个功能,不过基本都是用php来实现的。用了这个属性,无疑可以减少很多前端和后台的交流量和工作量。 新增属性二:autofocus autofocus 可以赋值为 autofocus,也就是在页面加载完成的时候自动聚焦到这个input标签,自然 type=”hidden”的时候是不能用的。 这个也是一个比较常见的效果,至今为止的实现方法是用js。在页面加载完时执行聚焦操作,现在也被一个属性搞定了。 可以想象,一个页面至多只有一个input标签会设置 autofocus,否则必然不会达到预期效果。因为不可能同事聚焦在两个input上。 新增属性三:required input的有一个强力新增属性,免去验证的麻烦。可以赋值为 required。 比如用户注册页面的用户名和密码都是必填的,只要设置一个required就可以了。而在以前是需要js来验证或者后台验证的。 注意:这里required属性是需要用户来填写的,所以TYPE是button、submit、reset、image等等不需要用户填写选择的类型是不可以使用这个属性的。 新增属性四:placeholder 这个新增属性也是非常使用,用在type= text email等等类型的时候,提示用户输入信息的格式或者内容等等。这个效果在之前也是需要js来实现的。是一种比较常见的效果: <!DOCTYPE HTML> </form>
新增属性五:新增list属性—联想框效果 这个属性显示类似于百度搜索框那种联想框效果,也是非常实用的一个属性。 注意从这个属性使用的特点:需要有对应的datalist标签;datalist子标签option支持 value和lable两个属性;list的属性值要和datalist的id一致。 使用示例 (opera支持) <!DOCTYPE HTML> 效果图
新增属性六: min、max属性来限制数值范围,minheight、maxheight属性来限制字符串长度。 其他新增属性: height、width设置高和宽 form、formaction、formmethod、fromtarget、formenctype等等属性来覆盖掉默认设置。 |
PHP将汉字转换成拼音的操作类
<?php
class pinyin{
/**
* 将字符串转化为拼音
* EDIT.JENA.20111213
*/
public static function _($_String, $_Code=’gb2312′) {
$_DataKey =”a|ai|an|ang|ao|ba|bai|ban|bang|bao|bei|ben|beng|bi|bian|biao|bie|bin|bing|bo|bu|ca|cai|can|cang|cao|ce|ceng|cha”.
“|chai|chan|chang|chao|che|chen|cheng|chi|chong|chou|chu|chuai|chuan|chuang|chui|chun|chuo|ci|cong|cou|cu|”.
“cuan|cui|cun|cuo|da|dai|dan|dang|dao|de|deng|di|dian|diao|die|ding|diu|dong|dou|du|duan|dui|dun|duo|e|en|er”.
“|fa|fan|fang|fei|fen|feng|fo|fou|fu|ga|gai|gan|gang|gao|ge|gei|gen|geng|gong|gou|gu|gua|guai|guan|guang|gui”.
“|gun|guo|ha|hai|han|hang|hao|he|hei|hen|heng|hong|hou|hu|hua|huai|huan|huang|hui|hun|huo|ji|jia|jian|jiang”.
“|jiao|jie|jin|jing|jiong|jiu|ju|juan|jue|jun|ka|kai|kan|kang|kao|ke|ken|keng|kong|kou|ku|kua|kuai|kuan|kuang”.
“|kui|kun|kuo|la|lai|lan|lang|lao|le|lei|leng|li|lia|lian|liang|liao|lie|lin|ling|liu|long|lou|lu|lv|luan|lue”.
“|lun|luo|ma|mai|man|mang|mao|me|mei|men|meng|mi|mian|miao|mie|min|ming|miu|mo|mou|mu|na|nai|nan|nang|nao|ne”.
“|nei|nen|neng|ni|nian|niang|niao|nie|nin|ning|niu|nong|nu|nv|nuan|nue|nuo|o|ou|pa|pai|pan|pang|pao|pei|pen”.
“|peng|pi|pian|piao|pie|pin|ping|po|pu|qi|qia|qian|qiang|qiao|qie|qin|qing|qiong|qiu|qu|quan|que|qun|ran|rang”.
“|rao|re|ren|reng|ri|rong|rou|ru|ruan|rui|run|ruo|sa|sai|san|sang|sao|se|sen|seng|sha|shai|shan|shang|shao|”.
“she|shen|sheng|shi|shou|shu|shua|shuai|shuan|shuang|shui|shun|shuo|si|song|sou|su|suan|sui|sun|suo|ta|tai|”.
“tan|tang|tao|te|teng|ti|tian|tiao|tie|ting|tong|tou|tu|tuan|tui|tun|tuo|wa|wai|wan|wang|wei|wen|weng|wo|wu”.
“|xi|xia|xian|xiang|xiao|xie|xin|xing|xiong|xiu|xu|xuan|xue|xun|ya|yan|yang|yao|ye|yi|yin|ying|yo|yong|you”.
“|yu|yuan|yue|yun|za|zai|zan|zang|zao|ze|zei|zen|zeng|zha|zhai|zhan|zhang|zhao|zhe|zhen|zheng|zhi|zhong|”.
“zhou|zhu|zhua|zhuai|zhuan|zhuang|zhui|zhun|zhuo|zi|zong|zou|zu|zuan|zui|zun|zuo”;$_DataValue = “-20319|-20317|-20304|-20295|-20292|-20283|-20265|-20257|-20242|-20230|-20051|-20036|-20032|-20026|-20002|-19990″.
“|-19986|-19982|-19976|-19805|-19784|-19775|-19774|-19763|-19756|-19751|-19746|-19741|-19739|-19728|-19725″.
“|-19715|-19540|-19531|-19525|-19515|-19500|-19484|-19479|-19467|-19289|-19288|-19281|-19275|-19270|-19263″.
“|-19261|-19249|-19243|-19242|-19238|-19235|-19227|-19224|-19218|-19212|-19038|-19023|-19018|-19006|-19003″.
“|-18996|-18977|-18961|-18952|-18783|-18774|-18773|-18763|-18756|-18741|-18735|-18731|-18722|-18710|-18697″.
“|-18696|-18526|-18518|-18501|-18490|-18478|-18463|-18448|-18447|-18446|-18239|-18237|-18231|-18220|-18211″.
“|-18201|-18184|-18183|-18181|-18012|-17997|-17988|-17970|-17964|-17961|-17950|-17947|-17931|-17928|-17922″.
“|-17759|-17752|-17733|-17730|-17721|-17703|-17701|-17697|-17692|-17683|-17676|-17496|-17487|-17482|-17468″.
“|-17454|-17433|-17427|-17417|-17202|-17185|-16983|-16970|-16942|-16915|-16733|-16708|-16706|-16689|-16664″.
“|-16657|-16647|-16474|-16470|-16465|-16459|-16452|-16448|-16433|-16429|-16427|-16423|-16419|-16412|-16407″.
“|-16403|-16401|-16393|-16220|-16216|-16212|-16205|-16202|-16187|-16180|-16171|-16169|-16158|-16155|-15959″.
“|-15958|-15944|-15933|-15920|-15915|-15903|-15889|-15878|-15707|-15701|-15681|-15667|-15661|-15659|-15652″.
“|-15640|-15631|-15625|-15454|-15448|-15436|-15435|-15419|-15416|-15408|-15394|-15385|-15377|-15375|-15369″.
“|-15363|-15362|-15183|-15180|-15165|-15158|-15153|-15150|-15149|-15144|-15143|-15141|-15140|-15139|-15128″.
“|-15121|-15119|-15117|-15110|-15109|-14941|-14937|-14933|-14930|-14929|-14928|-14926|-14922|-14921|-14914″.
“|-14908|-14902|-14894|-14889|-14882|-14873|-14871|-14857|-14678|-14674|-14670|-14668|-14663|-14654|-14645″.
“|-14630|-14594|-14429|-14407|-14399|-14384|-14379|-14368|-14355|-14353|-14345|-14170|-14159|-14151|-14149″.
“|-14145|-14140|-14137|-14135|-14125|-14123|-14122|-14112|-14109|-14099|-14097|-14094|-14092|-14090|-14087″.
“|-14083|-13917|-13914|-13910|-13907|-13906|-13905|-13896|-13894|-13878|-13870|-13859|-13847|-13831|-13658″.
“|-13611|-13601|-13406|-13404|-13400|-13398|-13395|-13391|-13387|-13383|-13367|-13359|-13356|-13343|-13340″.
“|-13329|-13326|-13318|-13147|-13138|-13120|-13107|-13096|-13095|-13091|-13076|-13068|-13063|-13060|-12888″.
“|-12875|-12871|-12860|-12858|-12852|-12849|-12838|-12831|-12829|-12812|-12802|-12607|-12597|-12594|-12585″.
“|-12556|-12359|-12346|-12320|-12300|-12120|-12099|-12089|-12074|-12067|-12058|-12039|-11867|-11861|-11847″.
“|-11831|-11798|-11781|-11604|-11589|-11536|-11358|-11340|-11339|-11324|-11303|-11097|-11077|-11067|-11055″.
“|-11052|-11045|-11041|-11038|-11024|-11020|-11019|-11018|-11014|-10838|-10832|-10815|-10800|-10790|-10780″.
“|-10764|-10587|-10544|-10533|-10519|-10331|-10329|-10328|-10322|-10315|-10309|-10307|-10296|-10281|-10274″.
“|-10270|-10262|-10260|-10256|-10254″;
$_TDataKey = explode(‘|’, $_DataKey);
$_TDataValue = explode(‘|’, $_DataValue);//array_combine:创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值
//PHP_VERSION:表示PHP的版本
$_Data = (PHP_VERSION>=’5.0′) ? array_combine($_TDataKey, $_TDataValue) : self::_Array_Combine($_TDataKey, $_TDataValue);
//arsort:对数组进行逆向排序并保持索引关系
//reset:将数组的内部指针指向第一个单元
arsort($_Data);
reset($_Data);if($_Code != ‘gb2312′) $_String = self::_U2_Utf8_Gb($_String);#假如编码不是gb2312,则启用utf-8
$_Res = ”;
for($i=0; $i<strlen($_String); $i++) {
$_P = ord(substr($_String, $i, 1));
if($_P>160) {
$_Q = ord(substr($_String, ++$i, 1));
$_P = $_P*256 + $_Q – 65536;
}
$_Res .= self::_Pinyin($_P, $_Data);
}
return preg_replace(“/[^a-z0-9]*/i”, ”, $_Res);
}private static function _Pinyin($_Num, $_Data) {
if($_Num>0 && $_Num<160 )
return chr($_Num);
elseif($_Num<-20319 || $_Num>-10247)
return ”;
else {
foreach($_Data as $k=>$v) {
if($v<=$_Num)
break;
}
return $k;
}
}private static function _U2_Utf8_Gb($_C) {
$_String = ”;
if($_C < 0×80) {
$_String .= $_C;
}
elseif($_C < 0×800) {
$_String .= chr(0xC0 | $_C>>6);
$_String .= chr(0×80 | $_C & 0x3F);
}
elseif($_C < 0×10000) {
$_String .= chr(0xE0 | $_C>>12);
$_String .= chr(0×80 | $_C>>6 & 0x3F);
$_String .= chr(0×80 | $_C & 0x3F);
}
elseif($_C < 0×200000) {
$_String .= chr(0xF0 | $_C>>18);
$_String .= chr(0×80 | $_C>>12 & 0x3F);
$_String .= chr(0×80 | $_C>>6 & 0x3F);
$_String .= chr(0×80 | $_C & 0x3F);
}
return @iconv(‘UTF-8′, ‘GB2312//IGNORE’, $_String);
}/**
* 等价PHP5版本的array_combine函数
*/
private static function _Array_Combine($_Arr1, $_Arr2) {
for($i=0; $i<count($_Arr1); $i++) $_Res[$_Arr1[$i]] = $_Arr2[$i];
return $_Res;
}
}
?>
html5
什么是 HTML5?
HTML5 将成为 HTML、XHTML 以及 HTML DOM 的新标准。
HTML 的上一个版本诞生于 1999 年。自从那以后,Web 世界已经经历了巨变。
HTML5 仍处于完善之中。然而,大部分现代浏览器已经具备了某些 HTML5 支持。
HTML5 是如何起步的?
HTML5 是 W3C 与 WHATWG 合作的结果。
编者注:W3C 指 World Wide Web Consortium,万维网联盟。
编者注:WHATWG 指 Web Hypertext Application Technology Working Group。
WHATWG 致力于 web 表单和应用程序,而 W3C 专注于 XHTML 2.0。在 2006 年,双方决定进行合作,来创建一个新版本的 HTML。
Linux下安装ZendOptimizer3.3.9后页面无法显示〔已解决〕
ZendOptimizer发布了新版本3.3.9 for Linux,于是乎及时跟进。
症状:成功安装后,phpinfo()显示正常,但是网站页面却打不开,显示“访问的页面不存在或输入网址有误,请确认” 。
解决方案:与已安装APC缓存模块有冲突,设置apc.enabled = 0,问题解决。
参考资料:http://kb.zend.com/index.php?View=entry&EntryID=150
php ini_set post_max_size,upload_max_filesize修改方法
ini_set(‘max_execution_time’,’10′);
ini_set(‘memory_limit’,’1024M’);
echo ‘max_execution_time = ‘ . ini_get(‘max_execution_time’) ;
echo ‘memory_limit = ‘ . ini_get(‘memory_limit’) ;
echo ‘post_max_size = ‘ . ini_get(‘post_max_size’);
echo ‘upload_max_filesize = ‘ . ini_get(‘upload_max_filesize’);
ini_set(‘max_execution_time’,’10′);
ini_set(‘memory_limit’,’1024M’);
注意: post_max_size,upload_max_filesize用下面的方法是修改不了的.
ini_set(‘post_max_size’,’1024M’);
ini_set(‘upload_max_filesize’,’1024M’);
正确做法是用.htaccess文件:
php_value upload_max_filesize 50M
php_value post_max_size 100M
前提是该站点在httpd.conf中配置了:
AllowOverride All
补充:
其实在php文档里有说明upload_max_filesize的可修改范围是PHP_INI_PERDIR。PHP_INI_PERDIR的意思是域内指令可以在php.ini、httpd.conf或.htaccess文件中修改。PHP_INI_SYSTEM 域内指令可以在php.ini和httpd.conf文件中修改所以upload_max_filesize用int_set是无法修改的。只有可修改范围是PHP_INI_ALL的才可以用int_set修改。
Flash+PHP文件上传,自定义样式,浏览器兼容,跨域上传
原文参见:http://www.cnblogs.com/kingthy/archive/2008/10/08/flex_file_uploader.html
我这里所做的修改:同一页面中可多次调用FLASH,解决IE,FIREFOX,CHROME,OPERA浏览器传值兼容问题,另外提供可跨域上传的解决办法。
————————————————-
2010-5-21 更新:默认语言为英文,将错误提示工作交给JS,根据错误类型自定义错误信息。
/*
*当Flash出现错误时(如上传文件)将触发此事件。
*error拥有两个属性
*error.type 错误类型
*error.value 错误信息
*/
__SWFUpload_OnError = function(objID, error){
switch(error.type){
case ‘size’:
alert(‘文件大小超出限制:’+error.value);
break;
default:
alert(error.value);
break;
}
__SWFUpload_GetMovie(objID).__SWFUpload_ResetUpload();
}
示例文件下载(Ver 1.1):Flex.FileUploader.1.1
PHP:header详解-页面刷新,页面跳转…
header() 函数会传送一个标题讯息给浏览器。因为这些讯息都遵循 HTTP 的规范, 因此浏览器会依据这些讯息做适当之响应。
header()格式:��int header ( string 标头宣告文字 [, bool 置换 [, int http回应码]])
–[标头宣告文字] 的内容就是传给浏览器的标题文字内容。
–[置换] 是布尔型态的参数。 设定为 True 时, 当有二的相同型态的标题讯息宣告时, 后面的讯息将会覆盖前一个讯息。
–第三个参数会让 HTTP 回应码给指定的值。
Location
Refresh
Content-type
Expires(意思为终止)
Last-Modified等。
Location – 浏览器显示指定的网页。
格式: header(“Location: http://绝对地址”);
Location 的地址必须是一个绝对地址。
Refresh
Refresh – 更新网页。
格式如下:��header(“Refresh : N ; URL=网址”)
–N 代表更新时间, 时间单位为秒。 URL 为更新后连结的网址。 如果省略 URL 就表示更新网页本身。
Content-type
Content-type – 定义网页内容的类型。
格式: Content-Type��= “Content-Type:” media-type
举例如下:
Header(“Content-type: text/html; charset=big5″) 设定网页内容为big5
Header(“Content-type: image/gif”) 设定网页内容为gif格式的图片
Header(“Content-type: application/pdf”) 设定网页内容为pdf档
Cache Control – Cache 的控制。
Cache Control 大致可以分成几种类型
设定过期时间。 当时间超过指定时间就表示网页内容已经失效。 其格式如下
Expires = “Expires:” HTTP-date
例 如: header(“Expires: Fri, 31 Oct 2003 18:00:00 GMT”); 表示2003年10月31日星期五 18时。
header(“Expires: Wed, 30 Jun 2004 09:00:00 GMT”); 表示2004年6月30日星期三 9时。
Last-Modified = “Last-Modified” “:” HTTP-date
例如 header(“Last-Modified: Wed, 01 Jan 2003 12:00:00 GMT”); 上次修改时间2003年1月1日12时
Cache Control
no-cache 使得服务器的数据可以传送到远程的使用者, 而不会被暂存 (cache) 起来。
no-store 是预防不良的版本或者是敏感的信息被保留下来。
must-revalidate 是指必须要再评估信息, 如果暂存 (cached) 的数据是无效的则让服务器与使用者端联机
Date 是说明数据内容的建立日期及时间。 其格式如下: Date = “Date:” HTTP-date
范例: header(“Date: Sun, 15 Feb 2004 08:00:00 GMT”); 建立日期是2004年2月15日8时。
使用 header() 函数认证
基本的认证就是使用账号密码窗体输入HTTP 认证。
窗体认 证:
<?php
if (($_POST['name'] != “john”) or ($_POST['passwd'] != “1234″)):
?>
<html>
<title>登入画面</title>
<body>
<B>未输入账号或密码, 或账号,密码不正确 </B><p>
<form action=<?php echo $_SERVER['PHP_SELF'] ?> method=post>
账号 <input type=text name=name value=”请输入账号” size=10><p>
密码 <input type=password name=passwd size=10><p>
<input type=submit value=” 登入 “>
<input type=reset value=” 清除 “>
</form>
</body>
</html>
<?php
else:
echo “登入成功 …..<p>”;
echo “您登入的账号是 “.$_POST['name'].”<br>”;
echo “您使用的密码是 “.$_POST['passwd'];
endif
?>
HTTP认证
<?php
if (empty($_SERVER['PHP_AUTH_USER'])) {
header(“Content-type: text/html; charset=big5″);
header(‘WWW-Authenticate: Basic realm=”认证范围”‘);
header(‘HTTP/1.0 401 Unauthorized’);
echo ‘请输入正确的账号及密码, 不可以取消!’;
exit;
} else {
echo “您登入的账号是 “.$_SERVER['PHP_AUTH_USER'].”<br>”;
echo “您使用的密码是 “.$_SERVER['PHP_AUTH_PW'].”<p>”;
$correctName=”john”;
$correctpwd=”1234″ ;
if (($_SERVER['PHP_AUTH_USER'] != $correctName) or
($_SERVER['PHP_AUTH_PW'] !=$correctpwd)){
echo “登入失败, 请开启新的浏览器重新登入”;
}else{
echo “登入成功…..”;
}
}
?>



