Popup弹出框添加数据实现方法


Posted in Javascript onOctober 27, 2017

本文实例为大家分享了Popup弹出框添加数据的具体代码,供大家参考,具体内容如下

逻辑

窗口P1中显示一组数据,并提供一个添加按钮
点击按钮,弹出新的浏览器窗口P2,在其中添加一条数据并提交后,窗口P2自动关闭
新添加数据动态添加到窗口P1中并被选中
所需知识:JS BOM 窗口对象;JS自执行函数

实现

下面在Django中简单实现下,因为比较简单,路由和视图就写在一起了。

1.路由和视图部分

from django.conf.urls import url
from django.shortcuts import render


def p1(request):
 return render(request, 'p1.html')

def p2(request):
 if request.method == 'GET':
  return render(request, 'p2.html')

 elif request.method == 'POST':
  city = request.POST.get('city')
  print('执行数据保存操作...')
  return render(request, 'popup.html',{'city':city})

urlpatterns = [
 url(r'^p1.html/', p1),
 url(r'^p2.html/', p2),
]

2.访问视图p1,返回页面p1.html:

<head>
 <meta charset="UTF-8">
 <title>p1页面</title>
</head>

<body>
<h2>p1页面</h2>

<select id="cityChoose">
 <option>上海</option>
 <option>北京</option>
</select>
<input type="button" value="添加" onclick="popupFunc();"/>

<script>
 popupFunc = function () {
  window.open('/p2.html/', 'p2', "status=1, height:300, width:300, toolbar=0, resizeable=1")
  //open(url, name, 窗口参数),注意name不能重名
 };

 callback = function (city) {
  var opt = document.createElement('option');
  opt.innerText = city;
  opt.setAttribute('selected', 'selected');
  var selEle = document.getElementById('cityChoose');
  selEle.appendChild(opt);
 }
</script>
</body>

说明:

1、点击添加按钮,执行popupFunc:访问'/p2.html/',并在新窗口中打开页面p2.html
2、定义回调函数callback:它接收一个参数city,将其动态添加到下拉选项中并设置为选中状态。

3.弹出窗口中显示p2.html如下:

<head>
 <meta charset="UTF-8">
 <title>p2页面</title>
</head>
<body>
<h2>p2页面</h2>

<form method="post">
 {% csrf_token %}
 <input type="text" name="city">
 <input type="submit" value="提交">
</form>
</body>

说明:这里没有指定form表单的action=url参数,用户输入数据后,默认提交到当前地址,即'/p2.html/',提交到视图p2

4.视图p2收到提交的数据后,传入模板并返回页面popup.html:

<head>
 <meta charset="UTF-8">
 <title>正在返回</title>
</head>
<body>
<script>

 (function (city) {
  window.opener.callback(city);
  window.close();
 })("{{ city }}")

</script>
</body>

说明:

  • 这里定义了JS自执行函数:它调用打开弹出窗口的窗口中的回调函数(即P1中的callback),并把用户输入数据作为参数传入;关闭自身。
  • 如果p2视图返回错误信息,也可以在popup.html中作显示(略)。
  • 自执行函数可以参考 JavaScript 自执行函数和 jQuery扩展方法

效果图:

Popup弹出框添加数据实现方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
form表单中去掉默认的enter键提交并绑定js方法实现代码
Apr 01 Javascript
javascript中为某个元素指定事件的三种方式
Aug 07 Javascript
详解JavaScript正则表达式中的global属性的使用
Jun 16 Javascript
详解JavaScript基于面向对象之继承
Dec 13 Javascript
Easyui笔记2:实现datagrid多行删除的示例代码
Jan 14 Javascript
javascript滚轮事件基础实例讲解(37)
Feb 14 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
Jan 10 Javascript
Vue官网todoMVC示例代码
Jan 29 Javascript
js中getter和setter用法实例分析
Aug 14 Javascript
Elasticsearch实现复合查询高亮结果功能
Sep 10 Javascript
微信小程序左滑删除实现代码实例
Sep 16 Javascript
js实现表格数据搜索
Aug 09 Javascript
JavaScript模拟实现封装的三种方式及写法区别
Oct 27 #Javascript
使用vue的v-for生成table并给table加上序号的实例代码
Oct 27 #Javascript
javascript浏览器用户代理检测脚本实现方法
Oct 27 #Javascript
vue中的event bus非父子组件通信解析
Oct 27 #Javascript
基于javascript中的typeof和类型判断(详解)
Oct 27 #Javascript
webpack配置之后端渲染详解
Oct 26 #Javascript
jquery使用iscorll实现上拉、下拉加载刷新
Oct 26 #jQuery
You might like
DISCUZ 分页代码
2007/01/02 PHP
php获取网卡的MAC地址支持WIN/LINUX系统
2014/04/30 PHP
可以用来调试JavaScript错误的解决方案
2010/08/07 Javascript
JQuery开发的数独游戏代码
2010/10/29 Javascript
ajax的hide隐藏问题解决方法
2012/12/11 Javascript
jquery 实现回车登录详解及实例代码
2016/10/23 Javascript
Vue.js一个文件对应一个组件实践
2016/10/27 Javascript
JavaScript仿支付宝6位数字密码输入框
2016/12/29 Javascript
View.post() 不靠谱的地方你知道多少
2017/08/29 Javascript
vue中实现图片和文件上传的示例代码
2018/03/16 Javascript
Node.js之readline模块的使用详解
2019/03/25 Javascript
微信小程序解析富文本过程详解
2019/07/13 Javascript
构建大型 Vue.js 项目的10条建议(小结)
2019/11/14 Javascript
Python下rrdtool模块的基本使用方法
2015/11/13 Python
Python数据结构之顺序表的实现代码示例
2017/11/15 Python
python操作redis方法总结
2018/06/06 Python
python对日志进行处理的实例代码
2018/10/06 Python
python使用phoenixdb操作hbase的方法示例
2019/02/28 Python
pandas DataFrame 交集并集补集的实现
2019/06/24 Python
Python绘制频率分布直方图的示例
2019/07/08 Python
django之状态保持-使用redis存储session的例子
2019/07/28 Python
Django之模板层的实现代码
2019/09/09 Python
Python List列表对象内置方法实例详解
2019/10/22 Python
python使用gdal对shp读取,新建和更新的实例
2020/03/10 Python
在Pytorch中使用Mask R-CNN进行实例分割操作
2020/06/24 Python
基于python tkinter的点名小程序功能的实例代码
2020/08/22 Python
[原创]赚疯了!转手立赚800+?大佬的python「抢茅台脚本」使用教程
2021/01/12 Python
Hoka One One法国官网:美国专业跑鞋品牌
2018/12/29 全球购物
酒店中秋节促销方案
2014/01/30 职场文书
中学生自我鉴定
2014/02/04 职场文书
2016幼儿园毕业感言
2015/12/08 职场文书
某药房的新员工入职告知书!
2019/07/15 职场文书
详解Java实践之适配器模式
2021/06/18 Java/Android
Python Pandas pandas.read_sql函数实例用法
2021/06/21 Python
python geopandas读取、创建shapefile文件的方法
2021/06/29 Python
Nginx+Tomcat负载均衡多实例详解
2022/04/11 Servers