如何在一个网站或者一个页面,去书写你的JS代码
// JavaScript Document
//如何在一个网站或者一个页面,去书写你的JS代码:
//1.js的分层(功能) : jquery(tools) 组件(ui) 应用(app), mvc(backboneJs)
//2.js的规划(管理) : 避免全局变量和方法(命名空间,闭包,面向对象) , 模块化(seaJs,requireJs)
window.onload = function(){
mv.app.toTip();
mv.app.toBanner();
mv.app.toSel();
mv.app.toRun();
};
var mv = {}; //命名空间
mv.tools = {};
mv.tools.getByClass = function(oParent,sClass){
var aEle = oParent.getElementsByTagName('*');
var arr = [];
for(var i=0;i<aEle.length;i++){
if(aEle[i].className == sClass){
arr.push(aEle[i]);
}
}
return arr;
};
mv.tools.getStyle = function(obj,attr){
if(obj.currentStyle){
return obj.currentStyle[attr];
}
else{
return getComputedStyle(obj,false)[attr];
}
};
mv.ui = {};
mv.ui.textChange = function(obj,str){
obj.onfocus = function(){
if(this.value == str){
this.value = '';
}
};
obj.onblur = function(){
if(this.value == ''){
this.value = str;
}
};
};
mv.ui.fadeIn = function(obj){
var iCur = mv.tools.getStyle(obj,'opacity');
if(iCur==1){ return false; }
var value = 0;
clearInterval(obj.timer);
obj.timer = setInterval(function(){
var iSpeed = 5;
if(value == 100){
clearInterval(obj.timer);
}
else{
value += iSpeed;
obj.style.opacity = value/100;
obj.style.filter = 'alpha(opacity='+value+')';
}
},30);
};
mv.ui.fadeOut = function(obj){
var iCur = mv.tools.getStyle(obj,'opacity');
if(iCur==0){ return false; }
var value = 100;
clearInterval(obj.timer);
obj.timer = setInterval(function(){
var iSpeed = -5;
if(value == 0){
clearInterval(obj.timer);
}
else{
value += iSpeed;
obj.style.opacity = value/100;
obj.style.filter = 'alpha(opacity='+value+')';
}
},30);
};
mv.ui.moveLeft = function(obj,old,now){
clearInterval(obj.timer);
obj.timer = setInterval(function(){
var iSpeed = (now - old)/10;
iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);
if(now == old){
clearInterval(obj.timer);
}
else{
old += iSpeed;
obj.style.left = old + 'px';
}
},30);
};
mv.app = {};
mv.app.toTip = function(){
var oText1 = document.getElementById('text1');
var oText2 = document.getElementById('text2');
mv.ui.textChange(oText1,'Search website');
mv.ui.textChange(oText2,'Search website');
};
mv.app.toBanner = function(){
var oDd = document.getElementById('ad');
var aLi = oDd.getElementsByTagName('li');
var oPrevBg = mv.tools.getByClass(oDd,'prev_bg')[0];
var oNextBg = mv.tools.getByClass(oDd,'next_bg')[0];
var oPrev = mv.tools.getByClass(oDd,'prev')[0];
var oNext = mv.tools.getByClass(oDd,'next')[0];
var iNow = 0;
var timer = setInterval(auto,3000);
function auto(){
if(iNow == aLi.length-1){
iNow = 0;
}
else{
iNow++;
}
for(var i=0;i<aLi.length;i++){
mv.ui.fadeOut(aLi[i]);
}
mv.ui.fadeIn(aLi[iNow]);
}
function autoPrev(){
if(iNow == 0){
iNow = aLi.length-1;
}
else{
iNow--;
}
for(var i=0;i<aLi.length;i++){
mv.ui.fadeOut(aLi[i]);
}
mv.ui.fadeIn(aLi[iNow]);
}
oPrevBg.onmouseover = oPrev.onmouseover = function(){
oPrev.style.display = 'block';
clearInterval(timer);
};
oNextBg.onmouseover = oNext.onmouseover = function(){
oNext.style.display = 'block';
clearInterval(timer);
};
oPrevBg.onmouseout = oPrev.onmouseout = function(){
oPrev.style.display = 'none';
timer = setInterval(auto,3000);
};
oNextBg.onmouseout = oNext.onmouseout = function(){
oNext.style.display = 'none';
timer = setInterval(auto,3000);
};
oPrev.onclick = function(){
autoPrev();
};
oNext.onclick = function(){
auto();
};
};
mv.app.toSel = function(){
var oSel = document.getElementById('sel1');
var aDd = oSel.getElementsByTagName('dd');
var aUl = oSel.getElementsByTagName('ul');
var aH2 = oSel.getElementsByTagName('h2');
for(var i=0;i<aDd.length;i++){
aDd[i].index = i;
aDd[i].onclick = function(ev){
var ev = ev || window.event;
var This = this;
for(var i=0;i<aUl.length;i++){
aUl[i].style.display = 'none';
}
aUl[this.index].style.display = 'block';
document.onclick = function(){
aUl[This.index].style.display = 'none';
};
ev.cancelBubble = true;
};
}
for(var i=0;i<aUl.length;i++){
aUl[i].index = i;
(function(ul){
var aLi = ul.getElementsByTagName('li');
for(var i=0;i<aLi.length;i++){
aLi[i].onmouseover = function(){
this.className = 'active';
};
aLi[i].onmouseout = function(){
this.className = '';
};
aLi[i].onclick = function(ev){
var ev = ev || window.event;
aH2[this.parentNode.index].innerHTML = this.innerHTML;
ev.cancelBubble = true;
this.parentNode.style.display = 'none';
};
}
})(aUl[i]);
}
};
mv.app.toRun = function(){
var oRun = document.getElementById('run1');
var oUl = oRun.getElementsByTagName('ul')[0];
var aLi = oUl.getElementsByTagName('li');
var oPrev = mv.tools.getByClass(oRun,'prev')[0];
var oNext = mv.tools.getByClass(oRun,'next')[0];
var iNow = 0;
oUl.innerHTML += oUl.innerHTML;
oUl.style.width = aLi.length * aLi[0].offsetWidth + 'px';
oPrev.onclick = function(){
if(iNow == 0){
iNow = aLi.length/2;
oUl.style.left = -oUl.offsetWidth/2 + 'px';
}
mv.ui.moveLeft(oUl,-iNow*aLi[0].offsetWidth,-(iNow-1)*aLi[0].offsetWidth);
iNow--;
};
oNext.onclick = function(){
if(iNow == aLi.length/2){
iNow = 0;
oUl.style.left = 0;
}
mv.ui.moveLeft(oUl,-iNow*aLi[0].offsetWidth,-(iNow+1)*aLi[0].offsetWidth);
iNow++;
};
};
如何在一个网站或者一个页面,去书写你的JS代码的更多相关文章
- 如何在一个网站或者一个页面规划JS
规划主要分为两部分:1.JS的分层,2.Js的规划 1.JS的分层(功能) 1-1.底层的库 : jquery 1-2.组件(ui) : 比如拖拽等,模块之间没有必然的联系,可以重复利用 1-3. ...
- Js 日期选择,可以的一个页面中重复使用本JS日历,兼容IE及火狐等主流浏览器,而且界面简洁、美观,操作体验也不错。
<html> <head> <title>Js日期选择器并自动加入到输入框中</title> <meta http-equiv="con ...
- 基于jquery的从一个页面跳转到另一个页面的指定位置的实现代码
比如 想跳到 mao.aspx 的页面 的div id="s" 的位置 那么 只用<a href="mao.aspx#s"> 就可实现跳转到指定位置 ...
- 常见的页面效果,相关的js代码
1.焦点图 $(document).ready(function(){ var i=0; var autoChange= setInterval(function(){ if(i<$(" ...
- 页面怎么引用外部css+js代码
外部css样式:把css样式写到一个文件内,方便使用,减少冗余. 如果使用的是外部css样式,页面怎么引用: 使用 <link rel="stylesheet" type=& ...
- 检测一个页面所用的时间的js
window.onload = function () { var loadTime = window.performance.timing.domContentLoadedEventEnd-wind ...
- jquery实现页面控件拖动效果js代码
;(function($) { var DragPanelId = "divContext"; var _idiffx = 0; var _idiffy = 0; var _Div ...
- html页面控制字体大小的js代码
dom对象控制显示文章字体大小的js代码 <head> <script type="text/javascript"> function check(siz ...
- 记录一个在线压缩和还原压缩js代码的工具
packer – javascript 压缩工具 http://dean.edwards.name/packer/ Javascript Beautifier ---可以恢复某些压缩工具压缩的js代码 ...
随机推荐
- Response.Write,Page.RegisterClientScriptBlock和Page.RegisterStartupScript的区别
Response.Write("<script>");输出在文件头部,一打开就执行. RegisterClientScriptBlock一般返回的是客户端函数的包装, ...
- Cleaner Robot - CodeForces 589J(搜索)
有一个M*N的矩阵,有一个会自动清洁的机器人,这个机器人会按照设定好的程序来打扫卫生,如果当前方向前面可以行走,那么直接走,如果不可以走那么会向右转动90度,然后回归上一步判断.求机器人最多能打扫的面 ...
- mysql 插入默认值的问题 sql-mode
刚好碰到如果不给默认值mysql数据就插入不成功的问题,后来百度了很多,试了下结果 把my.ini里面的[mysqld]的sql-mode 换成下面的一行,如果没有则添加 sql-mode=&quo ...
- tensorflow 保存变量,
代码: #!usr/bin/env python# coding:utf-8"""这个代码的作用是 通过 tensorflow 来计算 y = 0.3x + 0.1 的线 ...
- Shell脚本高级应用 --实现远程MySQL自动查询[转
#!/bin/sh Host=192.168.5.30 User=abccdef PW=123456 MSG=`mysql -h$Host -u$User -p$PW <<EOF show ...
- postgresql9.4新特性jsonb学习-update更新操作
先科普下概念:PgSQL9.4 新增 JSONB 数据类型, JSONB 同时属于 JSON (JavaScript Object Notation) 数据类型,jsonb 和 json 的输入数据几 ...
- 设置Win10文件资源管理器默认打开“这台电脑”
当Windows系统进入Win7之后,任务栏默认的文件资源管理器图标功能是“库”:Win8/Win8.1的这一按钮打开的是“这台电脑”.进入Win10之后,目前这一功能默认变为“快速访问”(曾经被称为 ...
- CreateEvent的使用方法
CreateEvent的使用方法收藏 新一篇: PreCreateWindow的作用和用法 | 旧一篇: VC中_T()的作用 function StorePage(){d=document;t=d ...
- checkbox复选框
改变checkbox状态 所有的jquery版本都可以这样赋值:// $("#cb1").attr("checked","checked") ...
- 基于Memcache的分布式缓存系统详解
文章不是简单的的Ctrl C与V,而是一个字一个标点符号慢慢写出来的.我认为这才是是对读者的负责,本教程由技术爱好者成笑笑(博客:http://www.chengxiaoxiao.com/)写作完成. ...