是时候写个自己的dialog了
组件下载地址:http://pan.baidu.com/s/1pJFVfej
最近做的项目需要用到对话框,但是原生的弹出框你是知道的。如果有时间,还是自己尝试一下,也是可以的。
一个简单图

里面的输入框是定制的,可以自己定制
最干净的对话框应该是这样的

很干净的对话框,如果没有信息的话。
其实对话框基本就三个部分
1.标题信息
2.提示信息
3.确认按钮
那么html组件结构就好写了。
<!--dialog-->
<div id="dialog" class="dialog">
<div class="dia_inner">
<h1 class="dia_title"></h1>
<div class="dia_msg"></div>
<div class="dia_btn"></div>
</div>
</div>
<!--dialog-->
所有对话框都是这样的结构,不需要改动,上面提到的三个信息,在js中添加进去。
先引入组件的css和js文件
<link href="css/dialog.css" rel="stylesheet" /> <script src="js/jquery-1.8.0.min.js"></script>
<script src="js/dialog.js"></script>
需要jquery是因为query比较方便
然后书写自己的js
上一个demo的代码
$(function(){
var dialog1 = new dialog({id:"dialog"});
$("#btn").click(function(){
dialog1.openDialog();
dialog1.clickbtn();
});
});
dialog()中的参数有四个
id:id
title:title
msg:msg
btntext:btntext
其中id是必填的,其他参数有默认值,就是上面第二个图的样子
现在上dialog.js的源码,如果你正好闲着,可以拷贝过去试试
/*
2015年5月22日10:51:10
QQ:503305196
*/ //对话框对象
function dialog(options){
this.init(options);//初始化方法
this.obj = $("#"+options.id);
this.closebtn();
} dialog.prototype = { init:function(options){
var title = options.title||"title";
var msg = options.msg||"msg";
var btntext = options.btntext||"btntext";
$("#"+options.id+" .dia_title").html(title+"<span class='dia_close'>×</span>");
$("#"+options.id+" .dia_btn").html("<button>"+btntext+"</button>");
},
/*打开回话框*/
openDialog: function(){
this.obj.animate({top:100},200);
},
/*关闭对话框*/
closeDialog: function(){
this.obj.animate({top:-300},200);
}, /*右上角关闭按钮*/
closebtn: function(){ var _obj = this.obj;
_obj.find(".dia_close").click(function(){
_obj.animate({top:-300},200);
});
},
/*点击确认按钮*/
clickbtn: function(fn){
var _obj = this.obj;
_obj.find(".dia_btn").click(function(){
_obj.animate({top:-300},200,fn);
}); }, /*自动隐藏对话框*/
autohide: function(dely){//dely延时多长时间自动隐藏 1000
var _obj = this.obj;
setTimeout(function(){
_obj.animate({top:-300},200);
},dely);
},
/*设置对画框的文本提示信息*/
setmsg:function(msg){
this.obj.find(".dia_msg").html(msg);
},
settitle:function(title){
this.obj.find(".dia_title").html(title+"<span class='dia_close'>×</span>");
}
}
希望大家给意见,本人也是js菜鸟。写得不好的地方希望大牛指出来。
第一个图中输入框的写法给予参考
dia1.setmsg("<input type='text' id='tel'/>");
其实就是在setmsg中换成标签就可以了。这样很简单。
是时候写个自己的dialog了的更多相关文章
- Easyui的Dialog的toolbar的自定义添加
最近一直在写快速定制Web表格,基于Easyui,整个过程使用了大量的Easyui的dialog,每个dialog的代码大部分都雷同,感觉代码出现了很大程度的重复,然后想写一个通用的dialog设置函 ...
- Easyui 创建dialog的两种方式,以及他们带来的问题
$('#yy').dialog('open');//打开dialog 这地方要注意,加入你关闭窗口的地方使用$('#yy').dialog('destroy');那么你这个dialog就只能使用一次, ...
- 简化MonoTouch.Dialog的使用
读了一位园友写的使用MonoTouch.Dialog简化iOS界面开发,我来做个补充: 相信使用过DialogViewController(以下简称DVC)的同学都知道它的强大,但是缺点也是明显的,应 ...
- Android开发技巧——使用Dialog实现仿QQ的ActionSheet菜单
最近看到有人用Dialog来实现QQ的仿ActionSheet的自定义菜单,对于自己没实现过的一些控件,看着也想实现一下.于是动手了一下,发现也不难,和大家分享一下. 本文原创,转载请注明出处:htt ...
- android 开发 实现一个activity变成dialog对话框
效果图: 首先说说为什么需要大费周章的去用activity实现一个dialog,明明android系统已经提供了一个更方便的dialog了.原因如下: 1.activity模式的dialog可以实现更 ...
- Android软件开发之盘点全部Dialog对话框大合集(一)
对话框大合集 今天我用自己写的一个Demo和大家具体介绍一个Android中的对话框的使用技巧. 1.确定取消对话框 个button 通过调用setPositiveButton方法和 setNeg ...
- 怎样使Dialog像Activity一样随心所欲的使用?
怎样使Dialog像Activity一样随心所欲的使用? android中的Dialog像是寄生在Activity中.在弹出Dialog时.因受到系统风格定义,导致Dialog怎么也不能如意,那么今天 ...
- 【Bugly干货分享】手把手教你逆向分析 Android 程序
很多人写文章,喜欢把什么行业现状啊,研究现状啊什么的写了一大通,感觉好像在写毕业论文似的,我这不废话,先直接上几个图,感受一下. 第一张图是在把代码注入到地图里面,启动首页的时候弹出个浮窗,下载网络的 ...
- 可拖动的DIV
在做WEB UI设计的时候,拖动某个HTML元素已经成为一种不能忽视的用户界面模式,比较典型的应用例子就是Dialog,一个元素是怎么实现拖动的呢?其实原理非常简单,要想实现首先得了解几个基本知识. ...
随机推荐
- ELK 安装Elasticsearch
章节 ELK 介绍 ELK 安装Elasticsearch ELK 安装Kibana ELK 安装Beat ELK 安装Logstash ELK栈要安装以下开源组件: Elasticsearch Ki ...
- python---生成式
1.[(x,y) for x in [1,2,3] for y in [4,2,3] if x == y] (x,y):输出表达式,产生最终列表的元素 for x in [1,2,3] for y i ...
- 面向对象第一个特征-封装(Encapsulation)
面向对象第一个特征-封装(Encapsulation) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.封装概述(Encapsulation) 1>.什么是封装 是指隐藏对 ...
- linux下的 sudo ln -s 源文件 目标文件
这是linux中一个非常重要命令,请大家一定要熟悉.它的功能是为某一个文件或目录在另外一个位置建立一个同步的链接,类似Windows下的超级链接. 这个命令最常用的参数是-s,具体用法是:sudo l ...
- Java IO 乱码
InputStreamReader isr = new InputStreamReader(new FileInputStream("./test/垃圾短信训练集80W条.txt" ...
- Swift实现iOS录音与播放音频功能
作用AVPLayer:可以用来播放在线及本地音视频AVAudioSession:音频会话,主要用来管理音频设置与硬件交互使用时需要导入 #import <AVFoundation/AVFound ...
- div自动适应高度
div高度100%<!DOCTYPE html> <html> <head></head> <body> <div id=" ...
- jQuery中的一些方法 19.5.20课上笔记
after() insertAfter():特定元素后面插入新的节点 before() insertBefore():特定元素前面插入新的节点 append() appendTo():向特定元素元素内 ...
- 「黑科技」智能消毒防疫机器人 技术方案介绍-disinfection robot
消毒机器人 小新防疫消杀机器人 - 自主导航全方位360°臭氧杀菌消毒机器人,采用臭氧无阻碍.无死角.遍布整个空间除菌:强力涡轮风机,30㎡室内空气循环6次/h,10分钟速效杀菌.除异味.自动转化为氧 ...
- c++ rand随机数生成(随机种子设置)
需求:每次初始化不同的随机数 1.默认 //这样用每次都会产生相同数字 #include <stdlib.h> #include <stdio.h> #define N 10 ...