在工作中,我们常常会遇到原生的样式感觉比较丑,又和我们做的项目风格不搭。于是就有了仿写原生一些组件的念头,今天我就带大家仿写一下confirm和alert样式都可以自己修改。

有些的不好的地方请指出来,让我们共同成长,如果有不懂的也可以私聊我,我会为你详细解说。

本文有以下三个段落

1.功能代码块展示,弹框功能尺寸适用手机在电脑上看会比较大。

//弹出对话框:传了cancel是confirm,不传就是alert弹框
function Confirm(obj) {
	let _obj = obj || {};
	//视图层
	let div = '<div id="_bj" style="">' +
			'<div id="Kuang" style="">' +
				'<h3 id="Tishi">提    示</h3>' +
				'<span id="_content"></span>' +
				'<div id="_cancel" class="XuanZhe" style="left:0;">取 消</div>' +
				'<div id="_determine" class="XuanZhe" style="right:0;border-left:0.5px solid gainsboro;">确  定</div>' +
			'</div>' +
		'</div>';
	$("body").append(div);

	//css样式层
	$("#_bj").css({
		position:"fixed",
		top:0,left:0,
		textAlign:"center",
		width:"100vw",
		height:"100vh",
		zIndex: 998,
		background:"rgba(0,0,0,.3)",
	});
	$("#Kuang").css({
		position:"absolute",
		textAlign:"center",
		top:"50%",left:"50%",
		transform:"translate(-50%,-50%)",
		width:"900px",
		height:"450px",
		background:"#f8f8f8",
		borderRadius:"20px",
		fontSize:"50px"
	});
	//传入一个选项是alert框,两个是confirm框
	if(_obj.cancel!=""&&_obj.cancel!=null){
		$(".XuanZhe").css({
			position:"absolute",
			textAlign:"center",
			width:"50%",
			color:"#287ae8",
			borderTop:"0.5px solid gainsboro",
			bottom:0,
			lineHeight:"150px"
		});
		$("#_cancel").html(_obj.cancel);
		//交互层
		$("#_cancel").click(function() {
			$("#_bj").remove();
			_obj.callback && _obj.callback(false);
		});
		$("#_determine").click(function() {
			$("#_bj").remove();
			_obj.callback && _obj.callback(true);
		});
	}else{
		$(".XuanZhe").css({
			position:"absolute",
			textAlign:"center",
			width:"100%",
			color:"#287ae8",
			borderTop:"0.5px solid gainsboro",
			borderLeft:"none",
			left:0,
			bottom:0,
			lineHeight:"150px"
		});
		$("#_cancel").hide();
		$("#_determine").click(function() {
			$("#_bj").remove();
			_obj.callback && _obj.callback();
		});
	}
	$("#_determine").html(_obj.determine);
	$("#_content").html(_obj.content || "确定吗");
}

2.代码调用说明

2.1调用时传了cancel,弹出的是confirm

$("#btn").click(function(){
  Confirm({
    content: "确定要删除吗",cancel:"取消",determine:"确定",
    callback: function(res) {//回调函数,返回true,false
      console.log(res);
    }
  });
});


2.2调用时没有传cancel,弹出的是alert
$("#btn").click(function(){
    Confirm({
        content: "你真的喜欢我吗?",determine:"确定",
        callback: function(res) {//回调函数没有返回值
            console.log("喜欢");
        }
    });
});

         

3.希望大家给点优化建议,让它更好的为广大的程序员们服务。

仿写confirm和alert弹框的更多相关文章

  1. selenium对Alert弹框的多种处理

    Alert弹框是一个很烦人的控件,因为当前页面如果弹出了该弹框,你必须要处理它,不然你就不能操作页面的其它元素,下面我列出了alert弹框在多种场景下的处理办法. 明确知道系统哪个地方会弹alert ...

  2. python工具 - alert弹框输出姓名年龄、求和

    使用python自带的tkinter库进行GUI编程,完成两个功能: (1)要求用户输入姓名和年龄然后打印出来 (2)要求用户输入一个数字,然后计算1到该数字之间的和 代码部分: # 导入tkinte ...

  3. 自定义alert弹框,title不显示域名

    问题: 系统默认的alert弹框的title会默认显示网页域名 解决办法: (修改弹框样式) (function() { window.alert = function(name) { $(" ...

  4. JavaScript实现自定义alert弹框

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAh0AAAFkCAYAAACEpYlzAAAfj0lEQVR4nO3dC5BddZ0n8F93pxOQCO

  5. 操作JavaScript的Alert弹框

    @Testpublic void testHandleAlert(){ WebElement button =driver.findElement(By.xpath("input" ...

  6. 自定义alert弹框,title不显示域名(重写alert)

    问题: 系统默认的alert弹框的title会默认显示网页域名 解决办法: (修改弹框样式) (function() { window.alert = function(name) { $(" ...

  7. 手写alert弹框(一)

    采用原生的JavaScript, html代码 <meta name="viewport" content="width=device-width, initial ...

  8. 如何优雅的写一个Vue 的弹框

    写Vue或者是react 都会遇见弹框的问题.也尝试了多种办法来写弹框,一直都不太满意,今天特地看了一下 Element UI 的源码,模仿着写了一个简易版. 大概有一下几个问题: 1.弹框的层级问题 ...

  9. CreateProcessAsUser,C#写的windows服务弹框提示消息或者启动子进程

    服务(Service)对于大家来说一定不会陌生,它是Windows 操作系统重要的组成部分.我们可以把服务想像成一种特殊的应用程序,它随系统的“开启-关闭”而“开始-停止”其工作内容,在这期间无需任何 ...

随机推荐

  1. 《用户体验要素》澄清了 UI 原型设计中看不见确感受得到的那一层

    <用户体验要素>澄清了看不见确感受得到的那一层 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一致&quo ...

  2. 一个Java工程师的入门级Linux命令集

    0.前言    网上介绍linux的命令的文章一大堆,但是大部分都是流于命令介绍,把命令的所有参数都介绍一遍,但是其实在真正的工作中,很多参数都不会用到.本文总结了我自己常用的一些命令,这些命令都比较 ...

  3. Blend_ControlTemplate(Z)

    原文:Blend_ControlTemplate(Z) 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010265681/article/deta ...

  4. 办ZigBee实验SmartRF Flash Programmer软件界面无法打开

    开SmartRF Flash Programmer: 打开任务管理器.在任务管理器里右键点击.将其最大化: 将最大化的界面拖动到屏幕中间: 然后关闭SmartRF Flash Programmer,之 ...

  5. WPF中用于嵌入其他进程窗口的自定义控件(AppContainer)

    原文:WPF中用于嵌入其他进程窗口的自定义控件(AppContainer) 版权声明:本文为博主原创文章,转载请注明作者和出处 https://blog.csdn.net/ZZZWWWPPP11199 ...

  6. Qt编程中QDiaog的ESC键(按下Esc键会默认调用reject()方法)

    最近使用QDialog时,按了下Esc键,导致QDialog被关闭,而后续的数据处理出现了问题.原来在QDialog中按下Esc键会默认调用reject()方法而不是closeEvent(QClose ...

  7. eclipse 配置maven tomcat 环境

    一  maven配置文件路径 二  tomcat 和JRE位置 三 validation 设置 四 五 六 设置run(debug) configurations 七 添加server时添加 reso ...

  8. WPF特效-拼图游戏

    原文:WPF特效-拼图游戏 此文主要描述我实现碎片化的便捷过程. 步骤1:    选取参考图如下(百度图库搜的): 步骤2:    根据效果图或者模型构建贝塞尔曲线,为了方便查看效果,可以设置控制点, ...

  9. WPF应用程序的启动画面[Splash Screen本质分析]

    原文:WPF应用程序的启动画面[Splash Screen本质分析] 不经意间发现了wpf的这个小玩意,感觉蛮有意思的.我在项目中添加了一张图片 如图: wpf-1.JPG(10.73 K) 2010 ...

  10. SQL Server 限制IP登陆(登陆触发器运用)

    原文:SQL Server 限制IP登陆(登陆触发器运用) 一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现代码(SQL Codes) 补 ...