appextend.js是自己编写的一个手机网页过渡时显示loading的一个js插件。

appextend.js :

var appExtend = function () {
this.setHide = null;
var $that = this;
function hideDialogDiv() {
$("#diag_bg_Box_x900AEB76").hide();
}; function addDialogDiv(obj) {
var windowHeight = $(document).height(); if (obj != null) {
windowHeight = $(obj).height();
} var html = "<div id=\"diag_bg_Box_x900AEB76\" class=\"diagBg\" style='height:" + windowHeight + "px; '><div id=\"diag_box_guid_x3F9AE\" class=\"diagContent\"><div id='dia_box_close_x3EB01F' onclick=\" $('#diag_bg_Box_x900AEB76').hide()\" style=\"border: 1px solid black;width: 19px;height: 15px;float: right;background:url('/Content/images/xx.png');position: relative;top: 18px;\"></div><div id=\"diag_content_box_x099065E3\" style=\"width:100%;height:100%;overflow:hidden;text-aline:center\"></div></div></div>"; if (obj != null) {
$(obj).append(html);
} else {
$("body").append(html);
}
}; function MessageBoxShow(obj, message, opt, fn) {
//try {
if ($("#diag_bg_Box_x900AEB76") != null && $("#diag_bg_Box_x900AEB76").length > 0) { } else {
addDialogDiv(obj);
} $("#diag_bg_Box_x900AEB76").css({ "left": 0 }).show();
$("#diag_content_box_x099065E3").html(message);
/*选项*/
if (opt != null) {
/*透明度*/
//if (opt.opacity != null && Number(opt.opacity) > 0) {
// $("#diag_bg_Box_x900AEB76").css({ opacity: Number(opt.opacity) / 100 });
//} else {
// $("#diag_bg_Box_x900AEB76").css({ opacity: 0.3 });
//}
/*关闭按钮*/
if (opt.close != null && !opt.close) {
$("#dia_box_close_x3EB01F").hide();
} else {
$("#dia_box_close_x3EB01F").show();
}
/*高度*/
if (opt.height != null) {
$("#diag_bg_Box_x900AEB76").css("height", opt.height);
} else {
var dh = obj != null ? $(obj).height() : $(document).height();
$("#diag_bg_Box_x900AEB76").css("height", opt.height);
}
/*边框*/
if (opt.border != null) {
$("#diag_content_box_x099065E3").css("border", opt.border);
} else {
$("#diag_content_box_x099065E3").css("border", "none");
} if (opt.bgzindex != null) {
$("#diag_bg_Box_x900AEB76").css("z-index", opt.bgzindex);
} else {
$("#diag_bg_Box_x900AEB76").css("z-index", "666");
}
if (opt.scrolltop != null) {
var top = $(window).scrollTop();
$("#diag_box_guid_x3F9AE").css("top", Number(top) + 100 + "px");
} else {
$("#diag_box_guid_x3F9AE").css("top", "30%");
}
if (opt.nobackimg != null) {
$("#diag_bg_Box_x900AEB76").css("background", "none");
} else {
$("#diag_bg_Box_x900AEB76").css("background", "url(../Content/images/pl_bg1.png) 0 0 repeat;");
}
} $("#diag_box_guid_x3F9AE").slideDown("fast"); if (fn != null && typeof fn === "function") {
fn();
} //} catch (e) {
// console.log(e.message);
//} }; /****propertys*****/
this.isHide = $("#diag_bg_Box_x900AEB76").is(':hidden'); //show loading background and image
this.showLoading = function (opt, loadthem, clearnHide) {
if (clearnHide) {
clearTimeout($that.setHide);
}
var _h = $(window).height();
opt = opt || {};
opt.close = false;
var loadstr = "";
switch (loadthem) {
case 'a':
loadstr = '<img style="margin-top:' + _h * 0.2 + 'px" src="/Content/images/ajax-loader.gif" />';
break;
case 'b':
loadstr = '<div class="loader"></div>';
break;
case 'c':
loadstr = '<div class="loader6"></div>';
break;
case 'd':
loadstr = '<div class="loader8"></div>';
break;
default:
loadstr = '<img style="margin-top:' + _h * 0.2 + 'px" src="/Content/images/ajax-loader.gif" />';
}
MessageBoxShow(null, loadstr, opt);
};
//hide loading background and image
this.loadingHide = function (t) {
t = t || "hide";
switch (t) {
case "hide":
$("#diag_bg_Box_x900AEB76").hide();
break;
case "slide":
$("#diag_bg_Box_x900AEB76").animate({ left: 0 - $(window).width() }, 1000, function () { $("#diag_bg_Box_x900AEB76").hide(); });
break;
case "slideUp":
$("#diag_bg_Box_x900AEB76").slideUp();
break;
default:
$("#diag_bg_Box_x900AEB76").hide();
}
};
this.transfer = function () {
var _h = $(window).height();
$("a[href*='/']").bind("click", function () {
// addDialogDiv({});
MessageBoxShow(null, '<img style="margin-top:' + _h * 0.2 + 'px" src="/Content/images/ajax-loader.gif" />', { close: false });
});
};
} var _app = new appExtend();
_app.showLoading(); $(function () {
_app.transfer();
_app.setHide = setTimeout(function () { _app.loadingHide("slide"); }, 300); });

css:

/****************遮罩样式****************/
.diagBg {
text-align: center;
position: absolute;
left: 0pt;
top: 0pt;
width: 100%;
z-index: 666;
/*-moz-opacity: 0.3;
opacity: .30;
filter: alpha(opacity = 30);*/
background: url(../Content/images/pl_bg1.png) 0 0 repeat;
} .diagContent {
position: absolute;
left: 10%;
top: 30%;
width: 80%;
height: 60%;
z-index: 999;
text-align: center;
} /**************laod***********/
.loader,
.loader:before,
.loader:after {
border-radius: 50%;
} .loader:before,
.loader:after {
position: absolute;
content: '';
} .loader:before {
width: 2.6em;
height: 5.2em;
background: #FFFFFF;
border-radius: 10.2em 0 0 10.2em;
top: -0.1em;
left: -0.1em;
-webkit-transform-origin: 2.6em 2.6em;
transform-origin: 2.6em 2.6em;
-webkit-animation: load2 2s infinite ease 1.5s;
animation: load2 2s infinite ease 1.5s;
} .loader {
font-size: 11px;
text-indent: -99999em;
margin: 30% auto;
position: relative;
width: 5em;
height: 5em;
box-shadow: inset 0 0 0 1em #999;
} .loader:after {
width: 2.6em;
height: 5.2em;
background: #FFFFFF;
border-radius: 0 3.2em 3.2em 0;
top: -0.1em;
left: 2.5em;
-webkit-transform-origin: 0px 2.6em;
transform-origin: 0px 2.6em;
-webkit-animation: load2 2s infinite ease;
animation: load2 2s infinite ease;
} @-webkit-keyframes load2 {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
} 100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
} @keyframes load2 {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
} 100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
} .loader6 {
font-size: 45px;
text-indent: -9999em;
overflow: hidden;
width: 1em;
height: 1em;
border-radius: 50%;
margin: 33% auto;
position: relative;
-webkit-animation: load6 1.7s infinite ease;
animation: load6 1.7s infinite ease;
} @-webkit-keyframes load6 {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
box-shadow: -0.11em -0.83em 0 -0.4em #999, -0.11em -0.83em 0 -0.42em #999, -0.11em -0.83em 0 -0.44em #999, -0.11em -0.83em 0 -0.46em #999, -0.11em -0.83em 0 -0.477em #999;
} 5%, 95% {
box-shadow: -0.11em -0.83em 0 -0.4em #999, -0.11em -0.83em 0 -0.42em #999, -0.11em -0.83em 0 -0.44em #999, -0.11em -0.83em 0 -0.46em #999, -0.11em -0.83em 0 -0.477em #999;
} 30% {
box-shadow: -0.11em -0.83em 0 -0.4em #999, -0.51em -0.66em 0 -0.42em #999, -0.75em -0.36em 0 -0.44em #999, -0.83em -0.03em 0 -0.46em #999, -0.81em 0.21em 0 -0.477em #999;
} 55% {
box-shadow: -0.11em -0.83em 0 -0.4em #999, -0.29em -0.78em 0 -0.42em #999, -0.43em -0.72em 0 -0.44em #999, -0.52em -0.65em 0 -0.46em #999, -0.57em -0.61em 0 -0.477em #999;
} 100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
box-shadow: -0.11em -0.83em 0 -0.4em #999, -0.11em -0.83em 0 -0.42em #999, -0.11em -0.83em 0 -0.44em #999, -0.11em -0.83em 0 -0.46em #999, -0.11em -0.83em 0 -0.477em #999;
}
} @keyframes load6 {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
box-shadow: -0.11em -0.83em 0 -0.4em #ffffff, -0.11em -0.83em 0 -0.42em #ffffff, -0.11em -0.83em 0 -0.44em #ffffff, -0.11em -0.83em 0 -0.46em #ffffff, -0.11em -0.83em 0 -0.477em #ffffff;
} 5%, 95% {
box-shadow: -0.11em -0.83em 0 -0.4em #ffffff, -0.11em -0.83em 0 -0.42em #ffffff, -0.11em -0.83em 0 -0.44em #ffffff, -0.11em -0.83em 0 -0.46em #ffffff, -0.11em -0.83em 0 -0.477em #ffffff;
} 30% {
box-shadow: -0.11em -0.83em 0 -0.4em #ffffff, -0.51em -0.66em 0 -0.42em #ffffff, -0.75em -0.36em 0 -0.44em #ffffff, -0.83em -0.03em 0 -0.46em #ffffff, -0.81em 0.21em 0 -0.477em #ffffff;
} 55% {
box-shadow: -0.11em -0.83em 0 -0.4em #ffffff, -0.29em -0.78em 0 -0.42em #ffffff, -0.43em -0.72em 0 -0.44em #ffffff, -0.52em -0.65em 0 -0.46em #ffffff, -0.57em -0.61em 0 -0.477em #ffffff;
} 100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
box-shadow: -0.11em -0.83em 0 -0.4em #ffffff, -0.11em -0.83em 0 -0.42em #ffffff, -0.11em -0.83em 0 -0.44em #ffffff, -0.11em -0.83em 0 -0.46em #ffffff, -0.11em -0.83em 0 -0.477em #ffffff;
}
} .loader8 {
margin: 6em auto;
font-size: 10px;
position: relative;
text-indent: -9999em;
border-top: 1.1em solid rgba(255, 255, 255, 0.3);
border-right: 1.1em solid rgba(255, 255, 255, 0.3);
border-bottom: 1.1em solid rgba(255, 255, 255, 0.3);
border-left: 1.1em solid #ffffff;
-webkit-animation: load8 1.1s infinite linear;
animation: load8 1.1s infinite linear;
} .loader8,
.loader8:after {
border-radius: 50%;
width: 2.5em;
height: 2.5em;
} @-webkit-keyframes load8 {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
} 100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
} @keyframes load8 {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
} 100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
}

实际应用1:

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="format-detection=no,initial-scale=1.0,maximum-scale=1.0,user-scalable=0,width=device-width" />
@Styles.Render("~/Content/public")
<script src="~/Scripts/lib/jquery-1.8.2.min.js"></script> </head> <body style="background:#F0F0F0;">
@Scripts.Render("~/bundles/appextend")
.......................

应用2:

在页面加载后加载数据效果:

js:

/// <reference path="../AppExtends.js" />
/// <reference path="base.js" />
/// <reference path="../lib/underscore.js" />
/// <reference path="../lib/iscroll.js" /> var shopcar = new basejs();
shopcar.ready = function (s) {
var model = shopcar.model;
_app.showLoading({ nobackimg: true }, 'd', true);
this.base.calcSize(); ......

appExtend.js的更多相关文章

  1. Vue.js 和 MVVM 小细节

    MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,其核心是提供对View 和 ViewModel 的双向数据绑定,这使得ViewModel 的状态改变可以自 ...

  2. js学习笔记:操作iframe

    iframe可以说是比较老得话题了,而且网上也基本上在说少用iframe,其原因大致为:堵塞页面加载.安全问题.兼容性问题.搜索引擎抓取不到等等,不过相对于这些缺点,iframe的优点更牛,跨域请求. ...

  3. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  4. JS调用Android、Ios原生控件

    在上一篇博客中已经和大家聊了,关于JS与Android.Ios原生控件之间相互通信的详细代码实现,今天我们一起聊一下JS调用Android.Ios通信的相同点和不同点,以便帮助我们在进行混合式开发时, ...

  5. jquery和Js的区别和基础操作

    jqery的语法和js的语法一样,算是把js升级了一下,这两种语法可以一起使用,只不过是用jqery更加方便 一个页面想要使用jqery的话,先要引入一下jqery包,jqery包从网上下一个就可以, ...

  6. 利用snowfall.jquery.js实现爱心满屏飞

    小颖在上一篇一步一步教你用CSS画爱心中已经分享一种画爱心的方法,这次再分享一种方法用css画爱心,并利用snowfall.jquery.js实现爱心满屏飞的效果. 第一步: 利用伪元素before和 ...

  7. node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理

    一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...

  8. JS正则表达式常用总结

    正则表达式的创建 JS正则表达式的创建有两种方式: new RegExp() 和 直接字面量. //使用RegExp对象创建 var regObj = new RegExp("(^\\s+) ...

  9. 干货分享:让你分分钟学会 JS 闭包

    闭包,是 Javascript 比较重要的一个概念,对于初学者来讲,闭包是一个特别抽象的概念,特别是ECMA规范给的定义,如果没有实战经验,很难从定义去理解它.因此,本文不会对闭包的概念进行大篇幅描述 ...

  10. JS核心系列:理解 new 的运行机制

    和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而在内存中分配一个实例对象. 但在 javascript 中,万物皆对象,为什么还要通过 ...

随机推荐

  1. 题解:CF718A Efim and Strange Grade

    CF718A Efim and Strange Grade 题解 算法 贪心+模拟 思路分析 显然,要最优每一次进位就只能五入不能四舍.而且当我们五入时,要取位数最高的.比如说 \(1.3535\), ...

  2. JDBC中数据库的连接与查询

    让我们仔细看看是怎么访问数据库的 package sql; import java.sql.Connection; import java.sql.DriverManager; import java ...

  3. 使用Ollama和Open WebUI管理本地开源大模型

    Open WebUI和Ollama介绍 Open WebUI 是一个功能丰富且用户友好的自托管 Web 用户界面(WebUI),它被设计用于与大型语言模型(LLMs)进行交互,特别是那些由 Ollam ...

  4. js逆向之常用算法

    [Python] encode & decode from urllib import parse # url进行编码与解码 url = '你好啊' url_encode = parse.qu ...

  5. 【邮件伪造】SPF与DKIM验证原理及实战解析(上)

    0x01 前言 大家好,我是VoltCary 本篇文章是系列邮件安全专题的第一篇,主要帮助大家掌握邮件安全的基础知识. 基础内容包括: SMTP协议 邮件安全验证原理与过程 SPF验证与DKIM签名验 ...

  6. 借助AI助手分析LlamaIndex的工作流可视化

    接续上次的讨论,我们上次主要分析了LlamaIndex工作流的核心流程,当前还剩下一行代码需要关注,那就是关于工作流的可视化.今天我们的目标是深入理解这一可视化部分的主要流程,并且对其大体的实现方式进 ...

  7. Sealos AI Proxy 发布!一个平台调用所有大模型,再也不用到处找 API 了

    你是一位开发者,你需要调用各类 AI 模型,每次调用模型,都要在不同的平台间反复横跳,你大概会遇到以下问题: 获取 API Key 流程繁琐:需访问多个厂商的官网,查阅各自的使用文档,并按照规定的步骤 ...

  8. 使用ProWindow时,控制按钮状态的说明

    在Pro SDK中,提供了一个默认的窗口基类,ProWindow Class,提供了基础的窗体样式,可供扩展和调用. 有网友问我,在使用时,会发现窗体右上角的控制按钮,有时会没有按照自己的预期显示. ...

  9. 前端每日一知之css隐藏页面元素

    脑图在线链接 本文内容依据[js每日一题]公众号精彩文章总结而来

  10. bitmap的特性和应用

    BitMap 是什么? BitMap 简称位图,实际上是一个散列表,只不过这个散列表中各个槽是计算机存储中的最小单元bit. 那BitMap数据结构长什么样呢? 一个长度为8的BitMap是下面这样的 ...