二级域名转向类


Posted in Javascript onNovember 09, 2006

DomainClass.js
/*
@Class DomainClass(二级域名转向类)
@author 逍遥云-http://bbs.51js.com
@Version 1.0
@Date 2006-11-2
@Rights 如使用请保留此信息,谢谢
*/

function DomainClass(){
 //记录本身
 var ōwner=this;
 //域名集合
 var arr=[];      
 //////////////////////////////////////公开属性
 //设定缺省目录
 owner.defaultDir="";  
 //设定缺省域名
 owner.defaultDomain="";  
 //设定缺省跳转网址
 owner.defaultURL="";
 //不存在的域名跳转
 owner.noExistURL="";
 /////////////////////////////////////公开方法
 //添加域名方法
 //参数1:域名 2:目录 3:输出域名 4:指定跳转地址
 owner.addDomain=function(){  
  if(arguments.length==0){
   return;
  }
  if(arguments.length>0){
   var tempObj=new Object();
   tempObj.domain=arguments[0]; //域名
   tempObj.dir="";     //对应目录
   tempObj.out="";     //输出域名
   tempObj.url="";        //指定跳转地址
  }
  if(arguments.length>1){
   tempObj.dir=arguments[1];
  }
  if(arguments.length>2){
   tempObj.out=arguments[2];
  }
  if(arguments.length>3){
   tempObj.url=arguments[3];
  }
  arr.push(tempObj);    //推入数组
 }
 //查找域名
 function seekDomain(href_loc){
  //取得二级域名头
  var loc=href_loc.split("//")[1].split(".")[0];
  for(var i=0;i<arr.length;i++){
   //判定域名
   if(arr[i].domain==loc){
    //跳转
    jumpWeb(href_loc,arr[i]);
    return;
   }
  }
  //不存在时处理的域名对象
  var notObj=new Object();
  notObj.out=owner.defaultDomain;
  notObj.dir=owner.defaultDir;
  notObj.url=owner.noExistURL;
  alert("提示:\n\n你还没有设置名为: \""+loc+"\" 这样的域名!");
  //域名头替换
  href_loc=href_loc.replace(/\/\/[^.]+/,"//"+notObj.out);
  jumpWeb(href_loc,notObj);
 }

 //跳转函数
 function jumpWeb(href_loc,obj){
  //判定跳转
  if(obj.url!=""){
   self.location=obj.url;
   return;
  }
  //替换空域名为默认
  if(obj.out==""){
   obj.out=owner.defaultDomain;
  }
  //域名替换
  href_loc=href_loc.replace(/\/\/[^.]+/,"//"+obj.out);
  //替换空目录为默认
  if(obj.dir==""){
   obj.dir=owner.defaultDir;
  }
  //目录替换
  href_loc=href_loc.replace(/(\/\/[^\/]+\/)/,"$1"+obj.dir+"\/");
  //重定义网址
  self.location=href_loc;
 }
 //初始化,公开
 owner.init=function(){
  //如果设置了默认跳转
  if(owner.defaultURL!=""){
   self.location=owner.defaultURL;
   return;
  }
  //如果没设缺省目录或缺省域名
  if(owner.defaultDir==""||owner.defaultDomain==""){
   alert("请设置:\n\n1.缺省目录:DomainClass.defaultDir.   \n\n2.缺省域名:DomainClass.defaultDomain   ");
  }
  else{
   seekDomain(self.location.href);
  }
 }
}

index.htm
<HTML>
<HEAD>
<TITLE> Loading.... </TITLE>
<scrīpt LANGUAGE="Javascrīpt" src="leon/code/javascrīpt/domainclass.js"></scrīpt>
</HEAD>

<BODY>
<scrīpt LANGUAGE="Javascrīpt">
<!--
var d=new DomainClass();
/*
defaultDir:默认跳转目录
defaultURL:默认全部跳转目录,如设置了此项,所有的请求就会以此为主
defaultDomain:默认输出域名
noExistURL:默认无此网址的跳转,如设置了此项,所有无网址的跳转都以此为主,如果无则为默认

addDomain:添加域名方法,最少一个参数,否则视无效

*/
//设置默认目录
d.defaultDir="pal";
//设置默认跳转
//d.defaultURL="http://hi.baidu.com/pallove";
//设置默认输出域名
d.defaultDomain="pal";
//添加二级域名
d.addDomain("pal","pal","pal");
d.addDomain("blog","blog","pal");
d.addDomain("leon","leon","love");
d.addDomain("51js","51js","51js","http://www.51js.com/11191");
d.addDomain("baidu","","","http://hi.baidu.com/pallove");
d.init();
//-->
</scrīpt>
</BODY>
</HTML>

详细效果请查看
URL跳出
无忧逍遥的Blog http://51js.pallove.net
百度空间 http://baidu.pallove.net
目录跳转
http://pal.pallove.net/
http://love.pallove.net
http://flash.pallove.net

在此考贝以上代码下载此类文件
http://pal.pallove.net/leon/code/javascrīpt/domainclass.js

如您使用或转载,请保留版权与个人信息。谢谢!

Javascript 相关文章推荐
jquery 简单导航实现代码
Sep 11 Javascript
jquery监听div内容的变化具体实现思路
Nov 04 Javascript
javascript实现des解密加密全过程
Apr 03 Javascript
node.js中的fs.unlink方法使用说明
Dec 15 Javascript
vue自定义指令实现v-tap插件
Nov 03 Javascript
基于BootStrap与jQuery.validate实现表单提交校验功能
Dec 22 Javascript
微信小程序 跳转传参数与传对象详解及实例代码
Mar 14 Javascript
关于Node.js的events.EventEmitter用法介绍
Apr 01 Javascript
Vue-cli创建项目从单页面到多页面的方法
Sep 20 Javascript
Bootstrap treeview实现动态加载数据并添加快捷搜索功能
Jan 07 Javascript
vue获取当前激活路由的方法
Mar 17 Javascript
JS实现分页导航效果
Feb 19 Javascript
JavaScript的面向对象(一)
Nov 09 #Javascript
JavaScript的面向对象(二)
Nov 09 #Javascript
利用javascript查看html源文件
Nov 08 #Javascript
用javascript获得地址栏参数的两种方法
Nov 08 #Javascript
Js+Dhtml:WEB程序员简易开发工具包(预先体验版)
Nov 07 #Javascript
Ucren Virtual Desktop V2.0
Nov 07 #Javascript
非常不错的一个javascript 类
Nov 07 #Javascript
You might like
php中的路径问题与set_include_path使用介绍
2014/02/11 PHP
Yii2中OAuth扩展及QQ互联登录实现方法
2016/05/16 PHP
PHP中mysqli_get_server_version()的实例用法
2020/02/03 PHP
用jquery实现点击栏目背景色改变
2012/12/10 Javascript
ajaxFileUpload.js插件支持多文件上传的方法
2014/09/02 Javascript
node.js中的fs.futimes方法使用说明
2014/12/17 Javascript
28个常用JavaScript方法集锦
2015/01/14 Javascript
js实现两点之间画线的方法
2015/05/12 Javascript
基于JavaScript实现鼠标向下滑动加载div的代码
2016/08/31 Javascript
JS实现直接运行html代码的方法
2017/03/13 Javascript
JavaScript实现反转字符串的方法详解
2017/04/27 Javascript
微信小程序 五星评分的实现实例
2017/08/04 Javascript
纯js实现页面返回顶部的动画(超简单)
2017/08/10 Javascript
在Vue中使用icon 字体图标的方法
2019/06/14 Javascript
微信小程序wx.request拦截器使用详解
2019/07/09 Javascript
layui的面包屑或者表单不显示的解决方法
2019/09/05 Javascript
layui lay-verify form表单自定义验证规则详解
2019/09/18 Javascript
Js实现复选框的全选、全不选反选功能代码实例
2020/02/28 Javascript
微信小程序实现简单购物车功能
2020/12/30 Javascript
基于进程内通讯的python聊天室实现方法
2015/06/28 Python
Python 获取当前所在目录的方法详解
2017/08/02 Python
Python查找最长不包含重复字符的子字符串算法示例
2019/02/13 Python
python图像处理入门(一)
2019/04/04 Python
python列表切片和嵌套列表取值操作详解
2020/02/27 Python
python 中 .py文件 转 .pyd文件的操作
2021/03/04 Python
表单button的outline在firefox浏览器下的问题
2012/12/24 HTML / CSS
css3边框_动力节点Java学院整理
2017/07/11 HTML / CSS
材料采购员岗位职责
2013/12/17 职场文书
酒店保安员岗位职责
2014/01/31 职场文书
成人继续教育实施方案
2014/03/01 职场文书
公司感恩节活动策划书
2014/10/11 职场文书
招商引资工作汇报材料
2014/10/28 职场文书
万能检讨书开头与结尾怎么写
2015/02/17 职场文书
2015年团支书工作总结
2015/04/03 职场文书
2016中秋节晚会开场白
2015/11/26 职场文书
2019西餐厅创业计划书范文!
2019/07/12 职场文书