ホームページ  >  記事  >  ウェブフロントエンド  >  window.js には主に page_javascript スキルに関するいくつかの操作が含まれています

window.js には主に page_javascript スキルに関するいくつかの操作が含まれています

WBOY
WBOYオリジナル
2016-05-16 18:38:31729ブラウズ
コードをコピー コードは次のとおりです:

//ページ例外の処理
function Exception() {
}

//ページ要素の共通インターフェース
function View() {
//Page要素
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( "位置", 位置 );
}
//レイヤーを設定します
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);
this.element.setAttributeNode(attr); }

/ /イベントリスニング
this.eventListener = function(eventName, exec) {
this.element.attachEvent(eventName, exec)
}
//マウスの移動into object event
this.onmouseenterListener = function(exec) {
this.eventListener("onmouseenter", exec);
}
//マウスアウトオブジェクトevent
this.onmouseleaveListener = function (exec) {
this.eventListener("onmouseleave", exec);
}
//マウスクリックオブジェクトevent
this.onclickListener = function(exec) {
this.eventListener( "onclick", exec);
}
}

//単一要素
関数 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);
}
}
}
//Panel
関数パネル() {
Multi.call(this);
//ページ要素を作成
this.element = document.body;
}
//ラインレイアウト
関数 LineLayout() {
Multi.call(this) ;
this.element = document.createElement("div")
}
//左レイアウト
function LeftLayout() {
Multi .call(this);
this .element = document.createElement("div");
}
//右レイアウト
関数() {
Multi.call(this);
this.element = document.createElement("div");
}
関数 メニュー() {
Multi.call( this);
this.element = document.createElement("div");
var clickListener = function( ) {
return;
};
var moveInBackgroundColor = "red";
this.show = function(); = null;
var menuEntiy = null ;
for(var i = 0; i < this.childElementList.length; i ) {
menuItem = new MenuItem(); childElementList[i];
menuEntity(menuEntiy);
menuItem.onmouseleaveListener(this.clickMenuItem); 🎜>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.offsetTopevent.srcElement.clientHeight);
child.show();
}
}
function ChildMenu() {
Multi.call(this);
this.element = document.createElement("div");
this.setPosition("絶対");
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 = 名前 ;
this.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("アクション", menuEntity.action);
}
}
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。