前情提要:
? ? ? ? 初学flask,我写了一个简单的登陆注册网页,当我点击登录按钮的时候会读取数据库里的信息判断是否存在该用户,然后返回一个参数给网页的JS,根据这个参数决定块呈现出来的内容,但当我实际使用时却发现不论返回的参数是什么,JS都会显示出找不到时的内容。
py文件部分代码
app = Flask(__name__,template_folder='html',static_folder="behind")#指定默认目录
app.config['DEBUG'] = True
@app.route('/')
def login():
return render_template('register.html')
@app.route('/login',methods=['GET','POST'])
def getdata():
name = request.form.get('name')
password = request.form.get('pasword')
sb = ''
sql_path = './s.accdb' # 暂时使用access
connection = pyodbc.connect("Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=" + sql_path)
con = connection.cursor()
sql = 'select ID,user_name,user_password from user_list'
data = list(con.execute(sql).fetchall())
name_list = [i[1] for i in data] # 获取所有用户名
connection.close()
if name in name_list and password == data[name_list.index(name)][2]: #找得到这个账号
return render_template('register.html', name=name)
else:
return render_template('register.html',sb='nono')
? ? ? ? 当我点击登录按钮的时候代码会查询数据库中是否存在该账号,如果存在则如实返回name,
若不存在则返回一个参数somebody = ‘nono’并且弹出提示,同时为了防止py部分报错,给somebody初定义为空。但实际操作时不管输入的账号是否存在都会弹出提示,于是猜测JS部分出现问题,不论是否传入somebody都会触发。
思路一:
? ? ? ? 使用块隐藏机制,提前写好块,根据传入参数决定显示哪个块而隐藏另一个。但是判断同样是在JS中进行,而且相对思路二需要改的地方更多。
思路二:
? ? ? ? 既然JS中无法执行 {%if sb !='nono'%} ,那就写在JS的外部,根据传入参数选择JS。虽然不能说改的少,但是至少更改位置集中。
html部分代码
<input type="submit" value="登录" style="position: absolute;width:40%;left:10px;" onclick="noname()"/></form>
原来的JS代码
function noname(){
{%if sb !='nono'%}
alert('不存在该账号')
{%endif%}
更改后JS代码
{%if sb !='nono'%}
function noname(){
alert('不存在该账号')}
{% else %}
function noname(){}
{%endif%}
|