>  기사  >  웹 프론트엔드  >  window.js에는 주로 page_javascript 기술에 대한 일부 작업이 포함되어 있습니다.

window.js에는 주로 page_javascript 기술에 대한 일부 작업이 포함되어 있습니다.

WBOY
WBOY원래의
2016-05-16 18:38:31730검색
코드 복사 코드는 다음과 같습니다.

//페이지 예외 처리
function Exception() {
}

//페이지 요소의 공통 인터페이스
function View() {
//Page elements
this.element = null;
//텍스트 색상
this.color = null

//스타일 설정
this.setStyle = function(이름, 값)
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);
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();
}
}
//Panel
함수 패널 () {
Multi.call( this);
//페이지 요소 생성
this.element = document.body
}
//라인 레이아웃
function LineLayout() {
Multi.call(this) ;
this.element = document.createElement("div")
}
//Left Layout
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")
}
함수 메뉴 () {
Multi.call( this);
this.element = document.createElement("div")
this.setWidth("100%")
var clickListener = function( ) {
return;
};
var moveInBackgroundColor = "red";
var moveOutBackgroundColor()
this.show = function() {
var menuItem = null;
var menuEntiy = null ;
for(var i = 0; i < this.childElementList.length; i ) {
menuItem = new MenuItem()
menuEntiy; childElementList[i];
menuItem.addMenuEntity(menuEntiy);
menuItem.onmouseleaveListener(moveOutMenuItem)
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("절대");
this.setZIndex(100);
this.setBackgroundColor("#ccffcc");
var moveInBackgroundColor = "빨간색";
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("없음");
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("왼쪽");
this.setWhiteSpace("nowrap");
this.addMenuEntity = function(menuEntity) {
this.setId(menuEntity.id);
this.setInnerText(menuEntity.name);
this.setAttributeIsNot("action", menuEntity.action);
}
}
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.