0

0

纯Javascript实现Windows 8 Metro风格实现_javascript技巧

php中文网

php中文网

发布时间:2016-05-16 17:19:53

|

1464人浏览过

|

来源于php中文网

原创

Metro风格设计主要特点

1.Windows 8 Metro风格设计,实现网站或系统功能的导航

2.纯Javascript实现

3.支持所有IE、360、Chrome等常用浏览器

4.支持圆角、阴影、卡片切换等特效

5.支持卡片的放大、缩小、增加、删除等功能

6.可自定义卡片背景色、背景图片、卡片图片、卡片文字

7.卡片间可任意切换

Metro风格截图
纯Javascript实现Windows 8 Metro风格实现_javascript技巧 
Metro部分算法

卡片显示部分代码:
复制代码 代码如下:

str='
  • ';
    str+='
    ';
    str+='
    ';
    str+='
  • ';

    移动单元格JS脚本:
    复制代码 代码如下:

    function moveItem(objid,indexList){
    //判断是否有效移动.
    var curItem=getCurItem(objid);
    var curIndex=curItem.index;
    for(var i=0;ivar miIndex=parseInt(indexList[i]);
    if((curIndex+1)==miIndex&&(curIndex+1)%colSize==0){
    alertInfo("最后一列不能调大!");
    return false;
    }
    if(miIndex>=(rowSize*colSize)){
    alertInfo("不能超过三行!");
    return false;
    }
    var cellnum=getItemCellNum(miIndex);
    if(cellnum!=1){
    alertInfo("被移动单元格目前只支持1个单元格!");
    return false;
    }
    }
    //判断是否超过所规定显示区域
    var nullnum=0;
    var nullIndexArray=new Array();
    for(var i=0;ivar tmpItem=itemArray[i];
    var objvalue=tmpItem.value;
    if(itemvalueforspace==objvalue||itemvaluefornull==objvalue){
    var isexitarea=false;
    for(var j=0;jvar miIndex=parseInt(indexList[j]);
    if(i==miIndex){
    isexitarea=true;
    break;
    }
    }
    nullnum=nullnum+1;
    if(!isexitarea){
    nullIndexArray.push(i);
    }
    }
    }
    if((itemArray.length-nullnum+indexList.length)>(rowSize*colSize)){
    alertInfo("调大单元格已超出所显示区域!");
    return false;
    }
    //调整移动单元格的队列.
    for(var i=0;ivar miIndex=parseInt(indexList[i]);
    var moveItem=itemArray[miIndex];
    if(moveItem==undefined){//不存在.
    for(var j=itemArray.length;jaddNullItem("");
    }
    moveItem=itemArray[miIndex];
    }
    //undefined
    var moveValue=moveItem.value;
    moveItem.value=curItem.value;
    itemArray[miIndex]=moveItem;
    if(moveValue!=itemvalueforspace){//覆盖单元格中已有对象.
    //覆盖单元格移到最后
    var moveIndex=itemArray.length;
    var col=moveIndex%colSize;
    var row=(moveIndex-col)/colSize;
    var moveLeft=splitspace+col*(initwidth+splitspace);
    var moveTop=splitspace+row*(initheight+splitspace);
    var moveCacheItem=new Object();
    moveCacheItem.index=moveIndex;
    moveCacheItem.id=itemPrefix+(moveIndex+1);
    moveCacheItem.x=moveLeft;
    moveCacheItem.y=moveTop;
    moveCacheItem.value=moveValue;
    itemArray.push(moveCacheItem);
    var moveObj=document.getElementById(moveValue);
    moveObj.style.top=moveTop+"px";
    moveObj.style.left=moveLeft+"px";
    }else{//null单元格,需要删除null单元格.
    //del(moveItem.id);
    }

    }

    //检查空缺单元格,如果存在,就填充null对象.
    for(var i=itemArray.length-1;i>=(rowSize*colSize);i--){
    var movitem=itemArray[i];
    var nulitemIndex=nullIndexArray[nullIndexArray.length-1];
    var nulitem=itemArray[nulitemIndex];
    var moveObj=document.getElementById(movitem.value);
    //console.log("id="+movitem.id+"//value="+movitem.value+"//top="+nulitem.y+"//left="+nulitem.x);
    moveObj.style.top=parseInt(nulitem.y)+"px";
    moveObj.style.left=parseInt(nulitem.x)+"px";
    //console.log("nullid="+nulitem.id+"//moveid="+movitem.id+"//value="+movitem.value+"//top="+nulitem.y+"//left="+nulitem.x);
    getElement(sortablecurid).removeChild(getElement(nulitem.id));
    nulitem.value=movitem.value;
    itemArray[nulitemIndex]=nulitem;
    itemArray.pop();
    nullIndexArray.pop();
    }

    printItemArray();
    return true;
    }

    待续……

    相关文章

    java速学教程(入门到精通)
    java速学教程(入门到精通)

    java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

    下载

    相关标签:

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    java连接字符串方法汇总
    java连接字符串方法汇总

    本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

    7

    2026.02.05

    java中fail含义
    java中fail含义

    本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

    8

    2026.02.05

    控制反转和依赖注入区别
    控制反转和依赖注入区别

    本专题整合了控制反转和依赖注入区别、解释、实现方法相关内容。阅读专题下面的文章了解更多详细教程。

    11

    2026.02.05

    钉钉脑图插图教程合集
    钉钉脑图插图教程合集

    本专题整合了钉钉脑图怎么插入图片、钉钉脑图怎么用相关教程,阅读专题下面的文章了解更多详细内容。

    24

    2026.02.05

    python截取字符串方法汇总
    python截取字符串方法汇总

    本专题整合了python截取字符串方法相关合集,阅读专题下面的文章了解更多详细内容。

    2

    2026.02.05

    Java截取字符串方法合集
    Java截取字符串方法合集

    本专题整合了Java截取字符串方法汇总,阅读专题下面的文章了解更多详细操作教程。

    1

    2026.02.05

    java 抽象方法
    java 抽象方法

    本专题整合了java抽象方法定义、作用教程等内容,阅读专题下面的文章了解更多详细内容。

    2

    2026.02.05

    Eclipse创建jsp文件教程合集
    Eclipse创建jsp文件教程合集

    本专题整合了Eclipse创建jsp文件、创建jsp项目等等内容,阅读专题下面的文章了解更多详细教程。

    26

    2026.02.05

    java 字符串转数字
    java 字符串转数字

    本专题整合了java如何字符串转数字相关内容,阅读专题下面的文章了解更多详细教程。

    4

    2026.02.05

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    React 教程
    React 教程

    共58课时 | 4.7万人学习

    TypeScript 教程
    TypeScript 教程

    共19课时 | 2.7万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3.2万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号