window.js 主要包含了页面的一些操作

 更新时间:2009年12月23日 18:48:00   作者:   我要评论
主要是获取页面元素的一些信息,所以明名为window.js,想要学习的朋友可以参考下。
复制代码 代码如下:

//处理页面异常
function Exception() {
}

//页面元素共同接口
function View() {
//页面元素
this.element = null;
//文字颜色
this.color = null;

//设置样式
this.setStyle = function(name, value) {
eval("this.element.style." + name + " = '" + value + "'");
}
//获取样式
this.getStyle = function(name) {
return eval("this.element.style." + name);
}

//设置浮动样式
this.setFloat = function(styleFloat) {
this.setStyle("styleFloat", styleFloat);
}
//设置背景色
this.setBackgroundColor = function(backgroundColor) {
this.setStyle("backgroundColor", backgroundColor);
}
//获取背景色
this.getBackgroundColor = function() {
return this.getStyle("backgroundColor");
}
//设置对象宽度
this.setWidth = function(width) {
//alert(width);
this.setStyle("width", width);
}
//设置对象宽度
this.setHeight = function(height) {
this.setStyle("height", height);
}
//设置页面定位
this.setPosition = function(position) {
this.setStyle("position", position);
}
//设置层
this.setZIndex = function(zIndex) {
this.setStyle("zIndex", zIndex);
}
//左边距离
this.setLeft = function(left) {
this.setStyle("left", left);
}
//上边距离
this.setTop = function(top) {
this.setStyle("top", top);
}
//是否换行
this.setWhiteSpace = function(whiteSpace) {
this.setStyle("whiteSpace", whiteSpace);
}
this.setMargin = function(margin) {
this.setStyle("margin", margin);
}
this.setPadding = function(padding) {
this.setStyle("padding", padding);
}

//设置属性
this.setAttributeIsHave = function(attrName, value) {
eval("this.element.setAttribute('" + attrName + "', '" + value + "')");
}
this.setId = function(id) {
this.setAttributeIsHave("id", id);
}
this.setInnerText = function(innertext) {
this.setAttributeIsHave("innerText", innertext);
}

//加入自定义属性
this.setAttributeIsNot = function(attrName, value) {
var attr = document.createAttribute(attrName);
attr.value = value;
this.element.setAttributeNode(attr);
}

//事件监听
this.eventListener = function(eventName, exec) {
this.element.attachEvent(eventName, exec);
}
//鼠标移入对象事件
this.onmouseenterListener = function(exec) {
this.eventListener("onmouseenter", exec);
}
//鼠标移出对象事件
this.onmouseleaveListener = function(exec) {
this.eventListener("onmouseleave", exec);
}
//鼠标单击对象事件
this.onclickListener = function(exec) {
this.eventListener("onclick", exec);
}
}

//单一元素
function Single() {
View.call(this);
}
//可以有子元素
function Multi() {
View.call(this);
//子元素集合
this.childElementList = new Array();
//加入子元素
this.addView = function(childElement) {
if(this.element == null) {
//待加入异常信息
return;
}
this.childElementList[this.childElementList.length] = childElement;
}
//关联子元素
this.appendChildElement = function(childElement) {
this.element.appendChild(childElement.element);
}
//显示元素
this.show = function() {
for(var i = 0; i < this.childElementList.length; i++) {
var childElement = this.childElementList[i];
this.appendChildElement(childElement);
childElement.show();
}
}
}
//面板
function Panel() {
Multi.call(this);
//创建页面元素
this.element = document.body;
}
//行布局
function LineLayout() {
Multi.call(this);
this.element = document.createElement("div");
}
//左布局
function LeftLayout() {
Multi.call(this);
this.element = document.createElement("div");
this.setFloat("left");
}
//右布局
function RightLayout() {
Multi.call(this);
this.element = document.createElement("div");
this.setFloat("right");
}
function Menu() {
Multi.call(this);
this.element = document.createElement("div");
this.setWidth("100%");
var clickListener = function() {
return;
};
var moveInBackgroundColor = "red";
var moveOutBackgroundColor = this.getBackgroundColor();
this.show = function() {
var menuItem = null;
var menuEntiy = null;
for(var i = 0; i < this.childElementList.length; i++) {
menuItem = new MenuItem();
menuEntiy = this.childElementList[i];
menuItem.addMenuEntity(menuEntiy);
menuItem.onmouseenterListener(moveInMenuItem);
menuItem.onmouseleaveListener(moveOutMenuItem);
menuItem.onclickListener(this.clickMenuItem );
menuItem.setPadding("0 5px 0 5px");
this.appendChildElement(menuItem);
}
}
this.setClickListener = function(exec) {
clickListener = exec;
}
function moveInMenuItem() {
event.srcElement.style.backgroundColor = moveInBackgroundColor;
}
function moveOutMenuItem() {
event.srcElement.style.backgroundColor = moveOutBackgroundColor;
}

this.clickMenuItem = function() {
var child = clickListener();
document.body.appendChild(child.element);
child.setLeft(event.srcElement.offsetLeft);
child.setTop(event.srcElement.offsetParent.offsetTop + event.srcElement.clientHeight);
child.show();
}
}
function ChildMenu() {
Multi.call(this);
this.element = document.createElement("div");
this.setPosition("absolute");
this.setZIndex(100);
this.setBackgroundColor("#ccffcc");
var moveInBackgroundColor = "red";
var moveOutBackgroundColor = this.getBackgroundColor();
this.show = function() {
var menuItem = null;
var menuEntiy = null;
for(var i = 0; i < this.childElementList.length; i++) {
menuItem = new MenuItem();
menuItem.setFloat("none");
menuEntiy = this.childElementList[i];
menuItem.addMenuEntity(menuEntiy);
menuItem.onmouseenterListener(moveInMenuItem);
menuItem.onmouseleaveListener(moveOutMenuItem);
//menuItem.onclickListener(clickMenuItem);
menuItem.setPadding("0 5px 0 15px");
this.appendChildElement(menuItem);
}
}
function moveInMenuItem() {
event.srcElement.style.backgroundColor = moveInBackgroundColor;
}
function moveOutMenuItem() {
event.srcElement.style.backgroundColor = moveOutBackgroundColor;
}
}

function MenuEntiy(id, name, action) {
this.id = id;
this.name = name ;
this.action = action;
}
function MenuItem() {
Single.call(this);
this.element = document.createElement("div");
this.setFloat("left");
this.setWhiteSpace("nowrap");
this.addMenuEntity = function(menuEntity) {
this.setId(menuEntity.id);
this.setInnerText(menuEntity.name);
this.setAttributeIsNot("action", menuEntity.action);
}
}

相关文章

  • js canvas实现橡皮擦效果

    js canvas实现橡皮擦效果

    这篇文章主要为大家详细介绍了使用Canvas实现橡皮擦效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • JS 实现图片直接下载示例代码

    JS 实现图片直接下载示例代码

    本文为大家详细介绍下使用JS实现图片直接下载,具体实现代码如下,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • js 颜色选择插件

    js 颜色选择插件

    本文主要介绍了js 颜色选择插件。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • 详解Layer弹出层样式

    详解Layer弹出层样式

    学习layer弹出框,之前项目是用bootstrap模态框,后来改用layer弹出框,在文章的后面,我会分享项目的一些代码,需要的朋友可以参考下
    2017-08-08
  • 原生javascript实现的全屏滚动功能示例

    原生javascript实现的全屏滚动功能示例

    这篇文章主要介绍了原生javascript实现的全屏滚动功能,涉及javascript事件响应及页面元素属性动态操作相关实现技巧,需要的朋友可以参考下
    2017-09-09
  • JS实现网页标题随机显示名人名言的方法

    JS实现网页标题随机显示名人名言的方法

    这篇文章主要介绍了JS实现网页标题随机显示名人名言的方法,涉及JavaScript中字符串、数组及随机数的相关操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • javascript常用的设计模式

    javascript常用的设计模式

    本文主要介绍了javascript常用的设计模式:单例模式;工厂模式;适配模式;外观模式。下面跟着小编一起来看下吧
    2017-02-02
  • 详解extract-text-webpack-plugin 的使用及安装

    详解extract-text-webpack-plugin 的使用及安装

    这篇文章主要介绍了详解extract-text-webpack-plugin 的使用及安装,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • COM组件中调用JavaScript函数详解及实例

    COM组件中调用JavaScript函数详解及实例

    这篇文章主要介绍了COM组件中调用JavaScript函数详解及实例的相关资料,需要的朋友可以参考下
    2017-02-02
  • 浅说js变量

    浅说js变量

    JavaScript 是弱类型, 变量可存储任意类型, 并且运行期间类型可变
    2011-05-05

最新评论