Python測試開發(fā)-創(chuàng)建模態(tài)框及保存數(shù)據(jù)

原創(chuàng): fin? 測試開發(fā)社區(qū)? 前天

什么是模態(tài)框翼雀?

? ? 模態(tài)框是指的在覆蓋在父窗體上的子窗體。可用來做交互编矾,我們經(jīng)常會看到模態(tài)框用來登錄熟史、確定等等,到底是怎么實現(xiàn)這種彈出效果窄俏,bootstrap已經(jīng)為我們提供了相應(yīng)的組件蹂匹。

1、界面原型

? ? 點擊添加凹蜈,彈出模態(tài)框限寞,

? ? 然后輸入 用戶:tester, 消息:你好仰坦。如下圖1所示:

圖片發(fā)自簡書App

圖1

? ? 再點擊保存履植,那么數(shù)據(jù)庫就存入了以上輸入的數(shù)據(jù),查看界面的用戶列表會顯示tester悄晃,如下圖2所示:

圖片發(fā)自簡書App

圖2

2玫霎、開發(fā)過程

接下來根據(jù)以上實例,一步一步教你編寫代碼妈橄。

首先搭建好Python環(huán)境--python3庶近,django2,mysql眷蚓,pycharm鼻种,等。

一 python數(shù)據(jù)模型 models.py溪椎,用于創(chuàng)建數(shù)據(jù)庫表存儲數(shù)據(jù)

clasTest(models.Model):

? ? ? ? name = models.CharField('名稱', max_length=200)

? ? ? ? message = models.CharField('消息', max_length=200)

? ? def __str__(self):

? ? ? ? return self.name


二 python邏輯處理視圖 view.py普舆,test函數(shù)用于顯示用戶列表,savedata函數(shù)用于模態(tài)框點擊保存時觸發(fā)保存數(shù)據(jù)校读。

def test(request):

? ? ? ? users = Test.objects.all()

? ? ? ? ? ? ? ? return render(request, 'test.html',{"users":users})

def savedata(request):

? ? if request.method == "POST":

? ? ? ? name = request.POST.get('name', '')

? ? ? ? message = request.POST.get('message', '')

? ? ? ? test_info = Test(name=name, message=message)

? ? ? ? test_info.save()

? ? ? ? return HttpResponse('save success!')


三 python鏈接 url.py沼侣,用于函數(shù)和頁面的關(guān)聯(lián)

path('test/',app_uitest_views.test),

path('savedata/', app_uitest_views.savedata),


四 前端模板頁面 test.html,用于前端展示用戶列表及js觸發(fā)模態(tài)框然后數(shù)據(jù)保存

<!DOCTYPE html>

<html lang="zh-CN">

<head>

<meta charset="utf-8">

<meta http-equiv="X-UA-Compatible"content="IE=edge">

<meta name="viewport"content="width=device-width, initial-scale=1">

<title>Bootstrap Modal</title>

<link rel="stylesheet">

</head>

<body>

<div class="panel panel-default">

<div class="panel-heading">用戶列表</div>

<div class="panel-body">

? <button type="button"class="list-group-item" data-toggle="modal" data-target="#exampleModal" > 添加</button>

? <div class="list-group"role="group" aria-label="用戶列表">

? ? ? {% for user in users %}

? ? ? ? ? <button type="button" class="list-group-item"data-toggle="modal" data-target="#exampleModal">{{ user.name }}</button>

? ? ? {% endfor %}

? </div>

</div>

</div>

<div class="modal fade" id="exampleModal" tabindex="-1"role="dialog" aria-labelledby="exampleModalLabel">

<div class="modal-dialog"role="document" style="width: 680px;">

? <div class="modal-content">

? <div class="modal-body">

? ? ? ? <div style="height:300px;overflow:auto;">

? ? ? ? ? <br><br><br><br>

? ? ? ? ? ? <p style="align:center">

? ? ? ? ? ? ? ? 用戶: <input style="align:center" type="text" name="name"id="name" required="required"/></p>

? ? ? ? ? ? <br>

? ? ? ? ? ? <p style="align:center">

? ? ? ? ? ? ? ? 消息: <input style="align:center" type="text" name="message"id="message" required="required"/></p>

? ? ? ? ? ? <br>

? ? ? ? </div>

? </div>

? <div class="modal-footer">

? ? <button type="button"class="btn btn-default" data-dismiss="modal">關(guān)閉</button>

? ? <button type="button"class="btn btn-primary" data-dismiss="modal" href="javascript:void(0)" onclick="savedata()">保存</button>

? </div>

? </div>

</div>

</div>

<script src="http://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>

<script src="http://cdn.bootcss.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>

? <script type="text/javascript">

? ? ? ? function savedata() {

? ? ? ? ? ? var name = $('#name').val();

? ? ? ? ? ? var message =$('#message').val();

? ? ? ? ? ? $.ajax({

? ? ? ? ? ? ? ? url:"/savedata/",

? ? ? ? ? ? ? ? data:"name=" +name + "&message=" + message,

? ? ? ? ? ? ? ? headers:{'X-CSRFToken':'{{ csrf_token }}'}, //csrf

? ? ? ? ? ? ? ? contentType:'application/x-www-form-urlencoded; charset=utf-8',

? ? ? ? ? ? ? ? type: "POST",

? ? ? ? ? ? ? ? success: function(result) {

? ? ? ? ? ? ? ? ? //? console.log();

? ? ? ? ? ? ? ? },

? ? ? ? ? ? ? ? fail: function (result) {

? ? ? ? ? ? ? ? ? ? debugger

? ? ? ? ? ? ? ? }

? ? ? ? ? ? });

? ? ? ? }

? </script>

</body>

</html>



前端關(guān)鍵代碼概覽如下

(注意紅色標示的代碼歉秫,代表了按鈕蛾洛,字段,模態(tài)框id雁芙,函數(shù)之間的關(guān)聯(lián))

1 創(chuàng)建模態(tài)框:

<button type="button"class="list-group-item" data-toggle="modal"data-target="#exampleModal" > 添加</button>

2 模態(tài)框內(nèi)容:

<div class="modal fade" id="exampleModal" tabindex="-1"role="dialog" aria-labelledby="exampleModalLabel">

用戶: <inputstyle="align:center" type="text" name="name" id="name" required="required"/></p>

消息: <input style="align:center"type="text" name="message" id="message"required="required"/></p>

<button type="button"class="btn btn-default" data-dismiss="modal">關(guān)閉</button>

<button type="button"class="btn btn-primary" data-dismiss="modal"href="javascript:void(0)" onclick="savedata()">保存</button>

3 Js及js函數(shù):

<link rel="stylesheet"></script>

function savedata()

{

? ? ? ? ? var name = $('#name').val();

? ? ? ? ? var message = $('#message').val();

? ? ? ? ? $.ajax({

? ? ? ? ? ? ? ? url: "/savedata/",

? ? ? ? ? ? ? ? data:"name="+ name + "&message=" + message,

? ? ? ? ? ? ? ? headers:{'X-CSRFToken': '{{csrf_token }}'}, //csrf

? ? ? ? ? ? ? ? contentType:'application/x-www-form-urlencoded; charset=utf-8',

? ? ? ? ? ? ? ? type: "POST",

? ? ? ? ? ? ? ? success: function (result) {

? ? ? ? ? ? ? ? //? console.log();

? ? ? ? ? ? ? ? },

? ? ? ? ? ? ? ? fail: function (result) {

? ? ? ? ? ? ? ? ? ? debugger

? ? ? ? ? ? ? ? }

? ? ? ? ? });

? ? ? }

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末轧膘,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子兔甘,更是在濱河造成了極大的恐慌谎碍,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洞焙,死亡現(xiàn)場離奇詭異蟆淀,居然都是意外死亡拯啦,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門熔任,熙熙樓的掌柜王于貴愁眉苦臉地迎上來褒链,“玉大人,你說我怎么就攤上這事疑苔「ζィ” “怎么了?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵惦费,是天一觀的道長兵迅。 經(jīng)常有香客問我,道長趁餐,這世上最難降的妖魔是什么喷兼? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮后雷,結(jié)果婚禮上季惯,老公的妹妹穿的比我還像新娘。我一直安慰自己臀突,他們只是感情好勉抓,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著候学,像睡著了一般藕筋。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上梳码,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天隐圾,我揣著相機與錄音,去河邊找鬼掰茶。 笑死暇藏,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的濒蒋。 我是一名探鬼主播盐碱,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼沪伙!你這毒婦竟也來了瓮顽?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤围橡,失蹤者是張志新(化名)和其女友劉穎暖混,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體翁授,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡儒恋,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年善绎,在試婚紗的時候發(fā)現(xiàn)自己被綠了黔漂。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诫尽。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖炬守,靈堂內(nèi)的尸體忽然破棺而出牧嫉,到底是詐尸還是另有隱情,我是刑警寧澤减途,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布酣藻,位于F島的核電站,受9級特大地震影響鳍置,放射性物質(zhì)發(fā)生泄漏辽剧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一税产、第九天 我趴在偏房一處隱蔽的房頂上張望怕轿。 院中可真熱鬧,春花似錦辟拷、人聲如沸撞羽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽诀紊。三九已至,卻和暖如春隅俘,著一層夾襖步出監(jiān)牢的瞬間邻奠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工为居, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留碌宴,地道東北人。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓颜骤,卻偏偏與公主長得像唧喉,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子忍抽,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容