W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
Sijax代表'Simple Ajax',它是一個Python/jQuery庫,旨在幫助您輕松地將Ajax引入到您的應(yīng)用程序。它使用jQuery.ajax來發(fā)出AJAX請求。
Flask-Sijax的安裝很簡單。
pip install flask-sijax
SIJAX_STATIC_PATH - 要被鏡像的Sijax javascript文件的靜態(tài)路徑。默認(rèn)位置是static/js/sijax。在此文件夾中,保留sijax.js和json2.js文件。
SIJAX_JSON_URI - 從中加載json2.js靜態(tài)文件的URI
Sijax使用JSON在瀏覽器和服務(wù)器之間傳遞數(shù)據(jù)。這意味著瀏覽器需要本機支持JSON或從json2.js文件支持JSON支持。
以這種方式注冊的函數(shù)不能提供Sijax功能,因為默認(rèn)情況下無法使用POST方法訪問它們(并且Sijax使用POST請求)。
要使View函數(shù)能夠處理Sijax請求,請使用@app.route('/url',methods = [\'GET\' ,\'POST\'])或使用@flask_sijax.route輔助裝飾器,如:
@flask_sijax.route(app, '/hello')
每個Sijax處理函數(shù)(像這樣)都會自動接收至少一個參數(shù),就像Python將'self'傳遞給對象方法一樣。'obj_response'參數(shù)是函數(shù)回復(fù)瀏覽器的方式。
def say_hi(obj_response):
obj_response.alert('Hi there!')
當(dāng)檢測到Ajax請求時,Sijax會像這樣處理它:
g.sijax.register_callback('say_hi', say_hi)
return g.sijax.process_request()
最小的Sijax應(yīng)用程序代碼如下:
import os
from flask import Flask, g
from flask_sijax import sijax
path = os.path.join('.', os.path.dirname(__file__), 'static/js/sijax/')
app = Flask(__name__)
app.config['SIJAX_STATIC_PATH'] = path
app.config['SIJAX_JSON_URI'] = '/static/js/sijax/json2.js'
flask_sijax.Sijax(app)
@app.route('/')
def index():
return 'Index'
@flask_sijax.route(app, '/hello')
def hello():
def say_hi(obj_response):
obj_response.alert('Hi there!')
if g.sijax.is_sijax_request:
# Sijax request detected - let Sijax handle it
g.sijax.register_callback('say_hi', say_hi)
return g.sijax.process_request()
return _render_template('sijaxexample.html')
if __name__ == '__main__':
app.run(debug = True)
上述代碼中的sijaxexample.html需要自行創(chuàng)建!
當(dāng)Sijax向服務(wù)器請求(特殊的jQuery.ajax()請求)時,g.sijax.is_sijax_request()會在服務(wù)器上檢測到此請求,在這種情況下,您讓Sijax處理請求。
使用g.sijax.register_callback()注冊的所有函數(shù)都會公開,以便從瀏覽器進行調(diào)用。
調(diào)用g.sijax.process_request()會告訴Sijax執(zhí)行適當(dāng)?shù)模ㄏ惹白缘模┖瘮?shù)并將響應(yīng)返回給瀏覽器。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: