目前,我的主页上有一个搜索栏和一个按钮,就像这样。
<div class="input-group">
<input id="address" type="textbox" placeholder="City or Zipcode" class="form-control">
<span class="input-group-btn">
<button class="btn btn-default" type="button" id="addressSearch">Search</button>
</span>
</div>
我创建了一个api.py文件,它位于我的网站文件夹中,看起来就是这样。
import urllib2
import json
locu_api = '****'
def loc_search(query):
api_key = locu_api
url = 'https://api.locu.com/v1_0/venue/search/?api_key=' + api_key
locality = query.replace(' ', '%20')
final_url = url + "&locality=" + locality + "&category=restaurant"
json_obj = urllib2.urlopen(final_url)
data = json.load(json_obj)
for item in data['objects']:
print item['name']
print item['phone']
基本上我要做的是当用户搜索城市时,例如纽约然后调用loc_search(查询),用用户输入填充搜索字段'(query)',然后显示数据。
我对django或api的经验都不多,所以任何帮助都是非常宝贵的。再次感谢
答案 0 :(得分:1)
我也没有真正体验过django,但已经工作了3个月了,我会建议你使用django-auto-complete-light或django-ajax-choices作为你的前端在导航栏中搜索,并在django-salmonela中搜索后端字段。那些都很有帮助。并且输入标记并不适用于您的django表单,因此您必须在div标记中使用一个类并使用{{form.fieldName}}显式调用每个表单字段然后使用用于引用模板标记的小部件,或者只使用上述知识如何更好地处理字段的软件包。
示例:
在您的模板中:
<div class="container text-center form-horizontal topSpace">
<form method="POST" enctype="multipart/form-data" action="{% url 'create-recipe' %}">
{% csrf_token %}
{{ form.non_field_errors }}
<div class="form-group">
{{ form.name.errors }}
<label for="{{ form.name.id_for_label }}" class="col-lg-4 control-label">Name:</label>
<div class="col-lg-1">
{# <input type="text" class="form-control" id="user-name" placeholder="Enter your name">#}
{{ form.name }}
</div>
</div><!-- end form-name-->
{{ form.as_p }}
<input type="submit" value="Add Recipe">
</form>
</div>
然后以你的形式:
class RecipeForm(autocomplete_light.ModelForm, forms.ModelForm):
class Meta:
model = Recipe
exclude = []