>屏蔽功能类
1.1 屏蔽键盘所有键
<script language="javascript">
<!--
function document.onkeydown(){
event.keycode = 0;
event.returnvalue = false;
}
-->
</script>
1.2 屏蔽鼠标右键
在body标签里加上oncontextmenu=self.event.returnvalue=false
或者
<script language="javascript">
<!--
function document.oncontextmenu()
{
return false;
}
-->
</script>
function nocontextmenu()
{
if(document.all) {
event.cancelbubble=true;
event.returnvalue=false;
return false;
}
}
或者
<body onmousedown="rclick()" oncontextmenu= "nocontextmenu()">
<script language="javascript">
<!--
function rclick()
{
if(document.all) {
if (event.button == 2){
event.returnvalue=false;
}
}
}
-->
</script>
1.3 屏蔽 ctrl+n、shift+f10、f5刷新、退格键
<script language="javascript">
<!--
//屏蔽鼠标右键、ctrl+n、shift+f10、f5刷新、退格键
function window.onhelp(){return false} //屏蔽f1帮助
function keydown(){
if ((window.event.altkey)&&
((window.event.keycode==37)|| //屏蔽 alt+ 方向键 ←
(window.event.keycode==39))){ //屏蔽 alt+ 方向键 →
alert("不准你使用alt+方向键前进或后退网页!");
event.returnvalue=false;
}
/* 注:这还不是真正地屏蔽 alt+ 方向键,
因为 alt+ 方向键弹出警告框时,按住 alt 键不放,
用鼠标点掉警告框,这种屏蔽方法就失效了。以后若
有哪位高手有真正屏蔽 alt 键的方法,请告知。*/
if ((event.keycode == 8) &&
(event.srcelement.type != "text" &&
event.srcelement.type != "textarea" &&
event.srcelement.type != "password") || //屏蔽退格删除键
(event.keycode==116)|| //屏蔽 f5 刷新键
(event.ctrlkey && event.keycode==82)){ //ctrl + r
event.keycode=0;
event.returnvalue=false;
}
if ((event.ctrlkey)&&(event.keycode==78)) //屏蔽 ctrl+n
event.returnvalue=false;
if ((event.shiftkey)&&(event.keycode==121)) //屏蔽 shift+f10
event.returnvalue=false;
if (window.event.srcelement.tagname == "a" && window.event.shiftkey)
window.event.returnvalue = false; //屏蔽 shift 加鼠标左键新开一网页
if ((window.event.altkey)&&(window.event.keycode==115)){ //屏蔽alt+f4
window.showmodelessdialog("about:blank","","dialogwidth:1px;dialogheight:1px");
return false;}
}
/* 另外可以用 window.open 的方法屏蔽 ie 的所有菜单
第一种方法:
window.open("你的.htm", "","toolbar=no,location=no,directories=no,menubar=no,scrollbars=no,resizable=yes,status=no,top=0,left=0")
第二种方法是打开一个全屏的页面:
window.open("你的.asp", "", "fullscreen=yes")
*/
//-->
</script>
1.4屏蔽浏览器右上角“最小化”“最大化”“关闭”键
<script language=javascript>
function window.onbeforeunload()
{
if(event.clientx>document.body.clientwidth&&event.clienty<0||event.altkey)
{
window.event.returnvalue = "";
}
}
</script>
或者使用全屏打开页面
<script language="javascript">
<!--
window.open(www.32pic.com,"32pic","fullscreen=3,height=100, width=400, top=0, left=0, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=no, status=no");
-->
</script>
注:在body标签里加上onbeforeunload="javascript:return false"(使不能关闭窗口)
1.5屏蔽f5键
<script language="javascript">
<!--
function document.onkeydown()
{
if ( event.keycode==116)
{
event.keycode = 0;
event.cancelbubble = true;
return false;
}
}
-->
</script>
1.6屏蔽ie后退按钮
在你链接的时候用 <a href="javascript:location.replace(url)">
1.7屏蔽主窗口滚动条
在body标签里加上 style="overflow-y:hidden"
1.8 屏蔽拷屏,不断地清空剪贴板
在body标签里加上onload="setinterval('clipboarddata.setdata(\'text\',\'\')',100)"
1.9 屏蔽网站的打印功能
<style>
@media print {
* { display: none }
}
</style>
1.10 屏蔽ie6.0 图片上自动出现的保存图标
方法一:
<meta http-equiv="imagetoolbar" content="no">
方法二:
<img galleryimg="no">
1.11 屏蔽页中所有的script
<noscrript></noscript>
<script language="javascript">
<!--
function checkform()
{
if (document.form.name.value.length == 0) {
alert("请输入您姓名!");
document.form.name.focus();
return false;
}
return true;
}
-->
</script>
2.2 比较两个表单项的值是否相同
<script language="javascript">
<!--
function checkform()
if (document.form.pwd.value != document.form.pwd_again.value) {
alert("您两次输入的密码不一样!请重新输入.");
document.adduser.pwd.focus();
return false;
}
return true;
}
-->
</script>
2.3 表单项只能为数字和"_",用于电话/银行帐号验证上,可扩展到域名注册等
<script language="javascript">
<!--
function isnumber(string)
{
var letters = "1234567890-"; //可以自己增加可输入值
var i;
var c;
if(string.charat( 0 )=='-')
return false;
if( string.charat( string.length - 1 ) == '-' )
return false;
for( i = 0; i < string.length; i ++ )
{
c = string.charat( i );
if (letters.indexof( c ) < 0)
return false;
}
return true;
}
function checkform()
{
if(! isnumber(document.form.tel.value)) {
alert("您的电话号码不合法!");
document.form.tel.focus();
return false;
}
return true;
}
-->
</script>
2.4 表单项输入数值/长度限定
<script language="javascript">
<!--
function checkform()
{
if (document.form.count.value > 100 || document.form.count.value < 1)
{
alert("输入数值不能小于零大于100!");
document.form.count.focus();
return false;
}
if (document.form.message.value.length<10)
{
alert("输入文字小于10!");
document.form.message.focus();
return false;
}
return true;
}
//-->
</script>
2.5 中文/英文/数字/邮件地址合法性判断
<script language="javascript">
<!--
function isenglish(name) //英文值检测
{
if(name.length == 0)
return false;
for(i = 0; i < name.length; i++) {
if(name.charcodeat(i) > 128)
return false;
}
return true;
}
function ischinese(name) //中文值检测
{
if(name.length == 0)
return false;
for(i = 0; i < name.length; i++) {
if(name.charcodeat(i) > 128)
return true;
}
return false;
}
function ismail(name) // e-mail值检测
{
if(! isenglish(name))
return false;
i = name.indexof("@");
j = name.lastindexof("@");
if(i == -1)
return false;
if(i != j)
return false;
if(i == name.length)
return false;
return true;
}
function isnumber(name) //数值检测
{
if(name.length == 0)
return false;
for(i = 0; i < name.length; i++) {
if(name.charat(i) < "0" || name.charat(i) > "9")
return false;
}
return true;
}
function checkform()
{
if(! ismail(form.email.value)) {
alert("您的电子邮件不合法!");
form.email.focus();
return false;
}
if(! isenglish(form.name.value)) {
alert("英文名不合法!");
form.name.focus();
return false;
}
if(! ischinese(form.cnname.value)) {
alert("中文名不合法!");
form.cnname.focus();
return false;
}
if(! isnumber(form.publiczipcode.value)) {
alert("邮政编码不合法!");
form.publiczipcode.focus();
return false;
}
return true;
}
//-->
</script>
2.6 限定表单项不能输入的字符
<script language="javascript">
<!--
function contain(str,charset)// 字符串包含测试函数
{
var i;
for(i=0;i<charset.length;i++)
if(str.indexof(charset.charat(i))>=0)
return true;
return false;
}
function checkform()
{
if ((contain(document.form.name.value, "%\(\)><")) || (contain(document.form.message.value, "%\(\)><")))
{
alert("输入了非法字符");
document.form.name.focus();
return false;
}
return true;
}
//-->
</script>
如对本文有疑问,
点击进行留言回复!!
网友评论