二级域名转向类


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 相关文章推荐
JavaScript的eval JSON object问题
Nov 15 Javascript
JQuery读取XML文件数据并显示的实现代码
Dec 16 Javascript
Jquery实现网页跳转或用命令打开指定网页的解决方法
Jul 09 Javascript
JS实现的DIV块来回滚动效果示例
Feb 07 Javascript
Three.js的使用及绘制基础3D图形详解
Apr 27 Javascript
微信小程序图片选择区域裁剪实现方法
Dec 02 Javascript
ng-repeat指令在迭代对象时的去重方法
Oct 02 Javascript
详解Vue项目部署遇到的问题及解决方案
Jan 11 Javascript
JavaScript Array对象使用方法解析
Sep 24 Javascript
微信小程序 下拉刷新及上拉加载原理解析
Nov 06 Javascript
9种方法优化jQuery代码详解
Feb 04 jQuery
vue postcss-px2rem 自适应布局
May 15 Vue.js
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实现用户认证及管理完全源码
2007/03/11 PHP
php 静态页面中显示动态内容
2009/08/14 PHP
joomla jce editor 解决上传中文名文件失败问题
2013/06/09 PHP
php ctype函数中文翻译和示例
2014/03/21 PHP
Yii调试SQL的常用方法
2014/07/09 PHP
PHP解码unicode编码的中文字符代码分享
2014/08/13 PHP
PHP编写文件多服务器同步程序
2016/07/02 PHP
PHP三种方式实现链式操作详解
2017/01/21 PHP
MAC下通过改apache配置文件切换php多版本的方法
2017/04/26 PHP
基于 Swoole 的微信扫码登录功能实现代码
2018/01/15 PHP
ext实现完整的登录代码
2008/08/08 Javascript
2014年最火的Node.JS后端框架推荐
2014/10/27 Javascript
jQuery中:disabled选择器用法实例
2015/01/04 Javascript
jQuery+CSS3实现树叶飘落特效
2015/02/01 Javascript
JavaScript中点击事件的写法
2016/06/28 Javascript
jQuery简单实现title提示效果示例
2016/08/01 Javascript
简单谈谈axios中的get,post方法
2017/06/25 Javascript
使用express+multer实现node中的图片上传功能
2018/02/02 Javascript
微信小程序网络封装(简单高效)
2018/08/06 Javascript
vue安装和使用scss及sass与scss的区别详解
2018/10/15 Javascript
Vue.js的动态组件模板的实现
2018/11/26 Javascript
微信小程序 bindtap 传参的实例代码
2020/02/21 Javascript
写给新手同学的vuex快速上手指北小结
2020/04/14 Javascript
Python中的time模块与datetime模块用法总结
2016/06/30 Python
python机器人运动范围问题的解答
2019/04/29 Python
Python3.8中使用f-strings调试
2019/05/22 Python
python爬虫项目设置一个中断重连的程序的实现
2019/07/26 Python
python实现本地批量ping多个IP的方法示例
2019/08/07 Python
利用css3实现的简单的鼠标悬停按钮
2014/11/04 HTML / CSS
BabyBjörn婴儿背带法国官网:BabyBjorn法国
2018/06/16 全球购物
客户表扬信范文
2014/01/10 职场文书
营销团队口号
2014/06/06 职场文书
推广普通话共筑中国梦演讲稿
2014/09/21 职场文书
2014法制宣传日活动总结范文
2014/11/01 职场文书
学雷锋广播稿大全
2015/08/19 职场文书
2016五一手机促销广告语
2016/01/28 职场文书