您好,欢迎访问一九零五行业门户网

Popup弹出框绑定添加数据事件(步奏详解)

这次给大家带来popup弹出框绑定添加数据事件(步奏详解),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扩展方法
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
js自执行函数与jquery扩展使用方法
require调用js使用详解
vue-resource拦截器设置头信息的步奏详解
以上就是popup弹出框绑定添加数据事件(步奏详解)的详细内容。
其它类似信息

推荐信息