【问题标题】:Running python file on HTML button click (Django)在 HTML 按钮单击上运行 python 文件(Django)
【发布时间】:2017-11-03 01:13:23
【问题描述】:

相关信息:

1) 第一次在这里发帖,慢慢来。

2) 我是菜鸟。

3) 尝试学习 python/Django。

我想做的事:

1) 创建一个英语 -> pig latin 翻译器(用 python 编写)并让它在浏览器中工作。

我希望它如何工作:

1) 用户点击“翻译”按钮,然后使用我现有的 python 函数来翻译他们的输入。

2) 然后翻译会显示在输入下方。

到目前为止我做了什么:

1) 创建 .py 文件,在控制台中成功翻译英语 -> pig latin。

def pigLatin(sentence):
translation = " "
for word in sentence.split():
    if word[0] in "aeiou":
        translation += word + "yay "
    if word[0] and word[1] not in "aeiou":
        translation += word[2:] + word[0:2] + "ay"
        print("hai")
    else:
        translation +=  word[1:] + word[0] + "ay "
return translation

sentence = input("Enter word/sentence you want translated to pig latin below: ")

print(pigLatin(sentence))

2) 使用 Jinja/添加了一些 HTML 和引导程序(请参见下文)

What it looks like in browser

3) 创建了一个 Django 项目,并安装了我的 pig latin 应用程序,我的文件夹结构如下:

--mysite
|
|--pigLatinApp
|----templates
|------pigLatinApp
|--------home.html
|--------header.html

3)尝试使用Ajax让我的按钮工作,我的HTML文件和views.py如下:

header.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title>Pig Latin Translator</title>
    {% load staticfiles %}
    <link rel="stylesheet" href="{% static 'css/bootstrap.min.css' %}" type="text/css">
</head>
<body class="body">    

<section id="translatorSection">
<!------------------Log Sum Container-------------------------->
    <div class="container" id="translatorContainer">
        {% block content %}
        {% endblock %}
    </div>           
</section>
<script src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-1.9.0.min.js">
</script>
</body>
</html>

home.html

{% extends "pigLatinApp/header.html" %}

{% block content %}
<div class="row">
    <div class="col-md-6">
        <form>
            <h3>Pig Latin Translator</h3>
                <p>Enter below what you want translated!</p>
                <input type="string" class="form-control" placeholder="Type what you want translated here!" id="inputSumA">
                <button id="translateToPig" class="btn btn-success form-control">Translate</button>
                <div id="displayTranslation">
                    <p>{{ output }}</p>
                </div> 
        </form>     
    </div>   
</div>
<script>
$("#translateToPig").click(function() {
    $.get("/output/", function(data) {
        $("#displayTranslation").html(data);
    }, "html");
});
</script>

{% endblock %}

views.py

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
    return render(request, 'pigLatinApp/home.html')

def output(request):
    if request.is_ajax():
        py_obj = pigLatinTranslator.test_code(10)
        return render(request, 'pigLatinApp/output.html', {'output': py_obj.a})

点击按钮时实际发生的情况:

1) 没什么...页面似乎在刷新。

我们将不胜感激,干杯!

【问题讨论】:

    标签: javascript jquery python html django


    【解决方案1】:

    这里:

    <script>
    $("#translateToPig").click(function() {
        $.get("/output/", function(data) {
            $("#displayTranslation").html(data);
        }, "html");
    });
    </script>
    

    您的click 事件处理程序不会阻止事件的默认操作,因此您的表单由浏览器提交。由于您的表单没有 'action' 属性,因此它被提交到当前 url,因此会调用索引视图并重新加载页面。

    您可以通过在事件上调用preventDefault() 来防止这种情况,即:

     <script>
    $("#translateToPig").click(function(evt) {
        evt.preventDefault(); # prevents posting the form
        evt.stopPropagation(); # make sure it doesn't bubble up
        $.get("/output/", function(data) {
            $("#displayTranslation").html(data);
        }, "html");
    });
    </script>
    

    现在您的代码中有几处可以改进,但这是另一个话题。至少我认为你应该首先尝试让 没有 ajax 的东西工作,这样你就可以了解整个请求/响应周期的东西,使用 GET 和 POST,使用 django 表单等。

    【讨论】:

    • 感谢您的回答,非常感谢。虽然,不幸的是,这似乎并没有解决它,它仍然只是刷新页面。我现在会看看让它在没有 Ajax 的情况下工作。
    • @R0bble 我已经在几十个项目中编写了类似的代码,我可以告诉你它确实按预期工作。唯一的区别是我通常在 $(document).ready() 处理程序中定义此类处理程序,但在您的情况下(使用脚本 after 标记)它不应该有所作为。您可能想使用浏览器的调试器来检查这里出了什么问题...
    • 我会这样做的,谢谢。另外,(对不起,如果这是一个愚蠢的问题),“冒泡”指的是什么?再次感谢。
    • 我会读一读,谢谢。感谢您的快速回复。
    【解决方案2】:

    我建议尝试一个普通的请求,即不是 ajax,还可以创建一个 form.py,您可以在其中创建一个用于搜索的表单类。在您看来,导入 pig latin 翻译函数并在您的 output 函数中调用它。

    【讨论】:

      最近更新 更多