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

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

逻辑

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

实现

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

1.路由和视图部分

rush:js;"> 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:

rush:xhtml;"> <Meta charset="UTF-8"> p1<a href="https://www.jb51.cc/tag/yemian/" target="_blank" class="keywords">页面</a>

p1页面

<select id="cityChoose">

添加" onclick="popupFunc();"/>

说明:

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

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

rush:xhtml;"> <Meta charset="UTF-8"> p2<a href="https://www.jb51.cc/tag/yemian/" target="_blank" class="keywords">页面</a>

p2页面

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

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

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

rush:xhtml;"> <Meta charset="UTF-8"> 正在返回

说明:

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

效果图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...