0

Dajax 不工作,我不明白为什么。我正在使用 Django 1.7

我的 ajax.py 文件如下所示:

from dajax.core import Dajax
from dajaxice.decorators import dajaxice_register

@dajaxice_register
def jmc_foundation_tower_number(request, option):

    print("It works!")

我的模板调用如下:

<div class='col-lg-3'>
  <select id='id_tower_number' name='tower_number' onchange="Dajaxice.core.views.jmc_foundation_tower_number(Dajax.process, {'option':$this.value})" onclick="Dajaxice.core.views.jmc_foundation_tower_number(Dajax.process, {'option':$this.value})" class='form-control'>
       {% for tower in towers %}
          <option value='{{ tower }}'>{{ tower }}</option>
       {% endfor %}
   </select>
</div>

我的 urls.py 如下:

from django.conf.urls import patterns, include, url
from django.contrib import admin

from dajaxice.core import dajaxice_autodiscover, dajaxice_config
dajaxice_autodiscover()


urlpatterns = patterns('',
    url(r'^index$', 'core.views.index', name='index'),

    url(r'^admin/', include(admin.site.urls)),
    url(dajaxice_config.dajaxice_url, include('dajaxice.urls')),

)
4

3 回答 3

1

django-dajaxdjango-dajaxice

我应该使用 django-dajax 还是 django-dajaxice?

总之,不。我在 4 年前创建了这些项目,作为一个很酷的工具,以解决我当时遇到的一个特定问题。

这些天使用这些项目是一个坏主意。(...) 如果你想使用这个项目,你可能错了。您应该停止将您的界面与后端耦合,否则......从长远来看,它会在您的脸上爆炸。

jorgebastida/django-dajax

于 2015-03-24T10:42:15.007 回答
0

显然,带有下划线('_')的javascript函数名称在使用像onclick这样的函数时不起作用。最好使用像somefunction()这样的函数而不是some_function()来使Dajax工作。

于 2014-11-06T12:05:39.910 回答
0

下面是一个使用 dajax 制作 Helloworld 的例子

模型.py:

 from django.db import models
 from dajax.core import Dajax
 from dajaxice.decorators import dajaxice_register
 @dajaxice_register
 def say_hello(request,value):
    dajax = Dajax()
    dajax.alert(value)
    return dajax.json()

网址.py:

urlpatterns = patterns('',
    # Examples:
    url(r'^$', 'server.views.index', name='index'),

其中 server.views.index 中的“server”是项目中的应用程序名称

在 index.html 文件中,您必须使用 jquery 函数来调用此 dajax 请求,如下 index.html:

 <html>
    <script>
      function print_helloworld(){
                var value = Dajaxice.server.models.say_hello(Dajax.process,{'value':'Hello World!'});
            }
    </script>
    <body>
       <button id='mybtn' class='btn btn-primary' onclick='print_helloworld()'>Hello World</button>
    </body>
 </html>

如果您需要从公共 ip 访问索引文件,则必须在按钮之前添加 {% csrf_token %} 令牌

于 2014-12-02T19:35:17.423 回答