日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

01: 实现注册登录功能

發布時間:2023/12/9 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 01: 实现注册登录功能 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄:抽屜項目之js最佳實踐

01: 實現注冊登錄功能

02: 實現發布帖子功能

03: 將帖子展示到頁面、點贊

04: 層級評論

目錄:

  • 1.1 顯示、隱藏 "登錄/注冊" 菜單
  • 1.2 注冊功能
  • 1.3 登錄功能
  • 1.4 獲取當前用戶數量

1.1 顯示、隱藏 "登錄/注冊" 菜單?????返回頂部

  1、此部分實現下面三個功能

      功能1:未登錄時在右上角顯示 “登錄/注冊” 菜單

      功能2:成功登錄后隱藏 “登錄/注冊” 菜單,顯示登錄用戶信息

      功能3:js設置初始化函數:鼠標滑過顯示注銷功能,檢查用戶已登錄直接顯示登錄信息,而不是"登錄/注冊"菜單

? ? ? ? ? ? ? ? ??

  2、相關code

<body><div class="header"><div class="w"><div class="login_or_register fr"><a href="javascript:void(0);" onclick="show_login_reg_frm()">登錄 / 注冊</a></div><div class="user_info fr"><span id="display_name" {% if is_login %}is_login{% endif %}>{{ user.display_name }}</span><div class="user_menu hide"><a>設置</a><a onclick="logout()">退出</a></div></div></div></div> </body> index.html html頁面 <body><script>/* 初始化函數 */$(function () {/* 處理是否登錄 */if($("#display_name")[0].hasAttribute("is_login")){// 已經登錄$(".login_or_register").addClass("hide");$(".user_info").removeClass("hide");}else {// 未登錄$(".login_or_register").removeClass("hide");$(".user_info").addClass("hide");}/* 用戶菜單是否顯示: 鼠標劃過就會觸發.hover綁定的函數 */$("div.user_info").hover(function () {show_user_menu(true);},function () {show_user_menu(false);});});</script> </body> index.html js初始化函數 /* 顯示登錄、注冊頁面 */ function show_login_reg_frm() {$("div.login_reg_frm").removeClass("hide");$("div.shelter").removeClass("hide"); }/* 注銷 */ function logout() {$.get({url: "/app01/logout/",dataType: "json",success:function (response) {if(response.status=='ok'){window.location.href="/app01/";}}}) }/* 用戶下拉菜單顯示開關 */ function show_user_menu(flag) {if(flag){$("div.user_menu").removeClass("hide");}else{$("div.user_menu").addClass("hide");} } base.js # 注銷 def logout(request):request.session['is_login'] = Falserequest.session['current_user'] = {}return HttpResponse(json.dumps({'status': 'ok'})) views.py

1.2 注冊功能?????返回頂部

?  1、此部分實現以下四個功能

    功能1:提交用戶注冊信息

    功能2:檢查用戶名和郵箱是否已注冊

    功能3:檢查兩次密碼是否一致

    功能4:創建驗證碼圖片標簽

? ? ? ? ?

  2、功能1提交用戶信息

<body><div class="shelter hide"><div class="login_reg_frm hide"><div class="close_login_reg_frm" onclick="close_login_reg_frm()">×</div><div class="reg_frm fl"><h1>注冊</h1><form method="post" id="register_frm"><table><tr><th>用戶名</th><td><input type="text" id="login_name" name="login_name" onblur="check_exist(this)"></td><td class="tips"></td></tr><tr><th>郵箱</th><td><input type="email" id="email" name="email" onblur="check_exist(this)"></td><td class="tips"></td></tr><tr><th>密碼</th><td><input id="password" type="password" name="password" autocomplete="off" minlength="3"></td><td class="tips"></td></tr><tr><th>確認密碼</th><td><input id="password2" type="password" name="password2" autocomplete="off" minlength="3" onblur="confirm_password()"></td><td class="tips"></td></tr><tr><th>驗證碼</th><td><input type="text" id="verify_code" name="verify_code" class="verify_code" maxlength="4" onclick="create_verify_code_img()"></td><td class="tips"></td></tr></table><div style="position: relative;"><a href="javascript:void(0);" onclick="register(this)">注冊</a><div class="reg_shelter hide"></div></div><br><div class="register_result"></div></form></div></div></div> </body> index.html html注冊界面 /* 提交用戶注冊信息 */ function register(ele) {// 數據檢查var check_pass = true;var check_list = {'login_name': '用戶名','email': '郵箱','password': '密碼','password2': '確認密碼','verify_code': '驗證碼'};for(var key in check_list){var val = $.trim($('.reg_frm #' + key).val());if(val.length==0){// 如果要檢查的input值為空,提醒用戶check_pass = false;$(".reg_frm #" + key).parent().parent().find('td:last-child').text("不能為空");}}if(!check_pass){return false;}// 通過檢查后var login_name = $.trim($('.reg_frm #login_name').val());var email = $.trim($('.reg_frm #email').val());var password = $.trim($('.reg_frm #password').val());var password2 = $.trim($('.reg_frm #password2').val());var verify_code = $.trim($('.reg_frm #verify_code').val());// 提交前,先將按鈕置為不可點擊$("div.reg_shelter").removeClass("hide");var data = $('#register_frm').serialize();console.log(data);$.post({url: "/app01/register/",data: data,dataType: "json",success: function (response) {console.log(response);if(response.hasOwnProperty("status")){if(response.status=='ok'){//console.log("注冊成功");$("div.register_result").text("注冊成功");setTimeout(function () {$("div.login_reg_frm").addClass("hide");$("div.shelter").addClass("hide");}, 2000);}else{$("div.reg_shelter").addClass("hide");$("div.register_result").text(response.msg);}}else{var ul = document.createElement('ul');for(var key in response){var li = document.createElement('li');li.innerText = response[key][0].message;ul.appendChild(li);}$("div.register_result").html(ul.outerHTML);$("div.reg_shelter").addClass("hide");}},error: function (xhr) {$("div.reg_shelter").addClass("hide");}});reload_verify_code(); // 無論結果如何,都刷新驗證碼 } base.js # 用戶注冊 def register(request):# 注冊的URLif request.method == 'POST':reg_frm = RegisterFrm(data=request.POST)if reg_frm.is_valid():cd = reg_frm.cleaned_data# 驗證碼比對vcode_from_client = cd.get("verify_code", "")vcode_in_session = request.session.get("verify_code")if vcode_from_client and vcode_in_session and vcode_from_client.upper() == vcode_in_session.upper():# 驗證碼比對通過new_user = reg_frm.save(commit=False)password2 = cd.get("password2")m = hashlib.md5()m.update(password2.encode())new_user.password = m.hexdigest()new_user.display_name = cd.get("login_name")new_user.email = cd.get("email")# new_user.last_login = datetime.datetime.now()new_user.last_login = timezone.now()new_user.last_ip = request.META.get("REMOTE_ADDR")new_user.save()# request.POST['verify_code'] = ""return HttpResponse(json.dumps({'status': 'ok'}))return HttpResponse(json.dumps({'status': 'fail', 'msg': '驗證碼不正確'}))else:return HttpResponse(reg_frm.errors.as_json()) views.py

  3、功能2檢查用戶名和郵箱是否已注冊

<tr><th>用戶名</th><td><input type="text" id="login_name" name="login_name" onblur="check_exist(this)"></td><td class="tips"></td> </tr> <tr><th>郵箱</th><td><input type="email" id="email" name="email" onblur="check_exist(this)"></td><td class="tips"></td> </tr> index.html 綁定事件 /* 檢查用戶名和郵箱是否已注冊 */ function check_exist(ele) {var t = ele.getAttribute("name");var v = ele.value;v = $.trim(v);if(v.length>0){$.post({url: "/app01/check_exist/",data: {"check_type": t, "check_value": v},dataType: "json",success: function (response) {var check_result = "";if(response.status=='ok'){// 沒有重復check_result = "√";}else{check_result = "已存在";ele.setAttribute("duplicate", "duplicate");}$(ele).parent().parent().find('td:last-child').text(check_result);}});} } base.js # 用戶注冊時,檢查提交的數據是否占用 def check_exist(request):# 檢查是否已存在相同的值if request.method == 'POST':check_type = request.POST.get("check_type")value = request.POST.get("check_value")parameter = {check_type: value}count = User.objects.filter(**parameter).count()if count > 0:return HttpResponse(json.dumps({'status': 'fail', 'msg': 'exist'}))else:return HttpResponse(json.dumps({'status': 'ok'})) views.py

  4、功能3檢查兩次密碼是否一致

<tr><th>密碼</th><td><input id="password" type="password" name="password" autocomplete="off" minlength="3"></td><td class="tips"></td> </tr> <tr><th>確認密碼</th><td><input id="password2" type="password" name="password2" autocomplete="off" minlength="3" onblur="confirm_password()"></td><td class="tips"></td> </tr> index.html 綁定事件 /* 檢查兩次密碼是否一致 */ function confirm_password() {if($('.reg_frm #password').val()!=$('#password2').val()){$('.reg_frm #password2').parent().parent().find('td:last-child').text("兩次密碼不一致");}else{$('.reg_frm #password').parent().parent().find('td:last-child').text("√");$('.reg_frm #password2').parent().parent().find('td:last-child').text("√");} } base.js

  5、功能4創建驗證碼圖片標簽?

<tr><th>驗證碼</th><td><input type="text" id="verify_code" name="verify_code" class="verify_code" maxlength="4" onclick="create_verify_code_img()"></td><td class="tips"></td> </tr> index.html 綁定事件 /* 創建驗證碼圖片標簽 */ function create_verify_code_img() {// 創建驗證碼圖片標簽,插入到驗證碼輸入框后面if(!document.getElementById('verify_code_img')){var img = document.createElement('img');img.id = 'verify_code_img';img.src = '/app01/verify_code/';img.className = 'verify_code';img.onclick = reload_verify_code;$("input.verify_code").after(img);} }/* 刷新驗證碼函數 */ function reload_verify_code() {var img = $('img.verify_code')[0];img.src += '?'; } base.js def verify_code(request):"""生成驗證碼圖片"""from backend import check_code as CheckCode # 該check_code是老師的驗證碼插件from io import BytesIO # BytesIO是內存Stream,用于存取二進制數據,可當文件handler用codeImg, strs = CheckCode.create_validate_code()request.session['verify_code'] = strsstream = BytesIO()codeImg.save(stream, 'png')return HttpResponse(stream.getvalue(), r'image/png') views.py import random from PIL import Image, ImageDraw, ImageFont, ImageFilter_letter_cases = "abcdefghjkmnpqrstuvwxy" # 小寫字母,去除可能干擾的i,l,o,z _upper_cases = _letter_cases.upper() # 大寫字母 _numbers = ''.join(map(str, range(3, 10))) # 數字 init_chars = ''.join((_letter_cases, _upper_cases, _numbers))def create_validate_code(size=(120, 30),chars=init_chars,img_type="GIF",mode="RGB",bg_color=(255, 255, 255),fg_color=(0, 0, 255),font_size=18,font_type="Monaco.ttf",length=4,draw_lines=True,n_line=(1, 2),draw_points=True,point_chance = 2):'''@todo: 生成驗證碼圖片@param size: 圖片的大小,格式(寬,高),默認為(120, 30)@param chars: 允許的字符集合,格式字符串@param img_type: 圖片保存的格式,默認為GIF,可選的為GIF,JPEG,TIFF,PNG@param mode: 圖片模式,默認為RGB@param bg_color: 背景顏色,默認為白色@param fg_color: 前景色,驗證碼字符顏色,默認為藍色#0000FF@param font_size: 驗證碼字體大小@param font_type: 驗證碼字體,默認為 ae_AlArabiya.ttf@param length: 驗證碼字符個數@param draw_lines: 是否劃干擾線@param n_lines: 干擾線的條數范圍,格式元組,默認為(1, 2),只有draw_lines為True時有效@param draw_points: 是否畫干擾點@param point_chance: 干擾點出現的概率,大小范圍[0, 100]@return: [0]: PIL Image實例@return: [1]: 驗證碼圖片中的字符串'''width, height = size # 寬, 高img = Image.new(mode, size, bg_color) # 創建圖形draw = ImageDraw.Draw(img) # 創建畫筆def get_chars():'''生成給定長度的字符串,返回列表格式'''return random.sample(chars, length)def create_lines():'''繪制干擾線'''line_num = random.randint(*n_line) # 干擾線條數for i in range(line_num):# 起始點begin = (random.randint(0, size[0]), random.randint(0, size[1]))#結束點end = (random.randint(0, size[0]), random.randint(0, size[1]))draw.line([begin, end], fill=(0, 0, 0))def create_points():'''繪制干擾點'''chance = min(100, max(0, int(point_chance))) # 大小限制在[0, 100]for w in range(width):for h in range(height):tmp = random.randint(0, 100)if tmp > 100 - chance:draw.point((w, h), fill=(0, 0, 0))def create_strs():'''繪制驗證碼字符'''c_chars = get_chars()strs = ' %s ' % ' '.join(c_chars) # 每個字符前后以空格隔開 font = ImageFont.truetype(font_type, font_size)font_width, font_height = font.getsize(strs)draw.text(((width - font_width) / 3, (height - font_height) / 3),strs, font=font, fill=fg_color)return ''.join(c_chars)if draw_lines:create_lines()if draw_points:create_points()strs = create_strs()# 圖形扭曲參數params = [1 - float(random.randint(1, 2)) / 100,0,0,0,1 - float(random.randint(1, 10)) / 100,float(random.randint(1, 2)) / 500,0.001,float(random.randint(1, 2)) / 500]img = img.transform(size, Image.PERSPECTIVE, params) # 創建扭曲 img = img.filter(ImageFilter.EDGE_ENHANCE_MORE) # 濾鏡,邊界加強(閾值更大)return img, strs /backend/check_code.py

1.3 登錄功能?????返回頂部

??  1、此部分實現以下四個功能

    功能1:提交用戶登錄信息

    功能2:對用戶提交信息驗證

  2、相關code

<body><div class="shelter hide"><div class="login_reg_frm hide"><div class="close_login_reg_frm" onclick="close_login_reg_frm()">×</div><div class="login_frm fl"><h1>登錄</h1><table><tr><th>用戶名</th><td><input type="text" name="login_name" class="login_name"></td></tr><tr><th>密碼</th><td><input type="password" name="password" class="password"></td></tr></table><a href="javascript:void(0);" onclick="login(this)">登錄</a><div class="login_result"></div></div></div></div> </body> index.html html登錄界面 /* 登錄 */ function login() {var login_name = $(".login_frm input.login_name").val();var password = $(".login_frm input.password").val();$.post({url: '/app01/login/',data: {'login_name': login_name, 'password': password},dataType: "json",success: function (response) {if(response.status=='ok'){// 登錄成功,讀取用戶昵稱和頭像$("div.login_result").text("登錄成功");var display_name = response.display_name;var head_pic = response.head_pic;$("span#display_name").text(display_name);$("img.head_pic").attr("src", head_pic);$("div.login_reg_frm").addClass("hide");$("div.shelter").addClass("hide");$(".user_info #display_name").attr("is_login", "");$(".user_info").removeClass("hide");$(".login_or_register").addClass("hide");get_online_users();}else{$("div.login_result").text(response.error);}},error: function (xhr) {}}); }/* 檢查是否登錄 */ function is_login() {return document.getElementById('display_name').hasAttribute('is_login'); }/* 隱藏登錄框 */ function close_login_reg_frm() {$("div.login_reg_frm").addClass("hide");$("div.shelter").addClass("hide"); } base.js # 登陸 def login(request):# 登錄視圖,檢查用戶名 + 密碼md5 ,不通過返回fail+驗證失敗# 檢查enable,不通過返回fail + 用戶已停用# 全部通過則返回ok+用戶昵稱+用戶頭像if request.method == 'POST':ret = {'status': '','error': '','display_name': '','head_pic': ''}login_name = request.POST.get("login_name")password = request.POST.get("password")if login_name and password:# 將密碼轉md5m = hashlib.md5()m.update(password.encode())password_md5 = m.hexdigest()# 獲取用戶對象user = User.objects.filter(login_name=login_name, password=password_md5).first()if user:# 檢查是否無效if user.enable:# 有效# 將用戶信息登記到session中request.session['is_login'] = Truerequest.session['current_user'] = {'id': user.id,'login_name': user.login_name,'display_name': user.display_name,}# 返回驗證通過信息+用戶昵稱+頭像url到客戶端ret['status'] = 'ok'ret['display_name'] = user.display_nameret['head_pic'] = settings.STATIC_URL + r'img/head/' + (user.head_pic or 'mxcp_320x320.jpg')else:ret['status'] = 'fail'ret['error'] = '該用戶已停用'else:ret['status'] = 'fail'ret['error'] = '用戶名或密碼不正確'else:ret['status'] = 'fail'ret['error'] = '用戶名或者密碼不能為空'return HttpResponse(json.dumps(ret)) views.py

1.4 獲取當前用戶數量?????返回頂部

<script>/* 初始化函數 */$(function () {/* 顯示在線用戶 */get_online_users();setInterval(get_online_users, 10000);});</script> 初始化函數中使用定時器實時跟新在線用戶數量 /* 獲取在線用戶 */ function get_online_users() {if(is_login()){var online_users_container = $("div.online_users_container");// 清理工作 online_users_container.children().remove();online_users_container.text("");// 獲取在線用戶 $.get({url:"/app01/get_online_users/",dataType:"json",success:function (response) {if(response.status=='ok'){console.log(response);var users = response.data;online_users_container.text("在線用戶列表:");for(var key in users){var user_a = document.createElement('a');user_a.innerText=users[key]['display_name'];user_a.setAttribute("user_id", users[key]['id']);user_a.href = "javascript:void(0);";online_users_container.append(user_a);}}}});} } get_online_users(js) 獲取在線用戶數量 def get_online_users(request):current_user = request.session.get("current_user")current_user_id = current_user.get("id")current_time = timezone.now()td = datetime.timedelta(**settings.LOGIN_PARAMETERS['ONLINE_INTERVAL'])users = User.objects.exclude(id=current_user_id, ).filter(is_login=True,last_login__gte=(current_time + td)).values("id", "head_pic", "display_name",)users_list = list(users)return HttpResponse(json.dumps({'status': 'ok','data': users_list})) views.py 從數據庫中統計在線用戶數量

?

附加:js代碼(四個大功能點)

// 第一部分:實現登錄注冊功能 /* ajax檢查數據是否已被注冊使用 */ function check_exist(ele) {var t = ele.getAttribute("name");var v = ele.value;v = $.trim(v);if(v.length>0){$.post({url: "/app01/check_exist/",data: {"check_type": t, "check_value": v},dataType: "json",success: function (response) {// console.log(response);var check_result = "";if(response.status=='ok'){// 沒有重復check_result = "√";}else{check_result = "已存在";ele.setAttribute("duplicate", "duplicate");}$(ele).parent().parent().find('td:last-child').text(check_result);}});} }function register(ele) {// 數據檢查var check_pass = true;var check_list = {'login_name': '用戶名','email': '郵箱','password': '密碼','password2': '確認密碼','verify_code': '驗證碼'};for(var key in check_list){var val = $.trim($('.reg_frm #' + key).val());if(val.length==0){// 如果要檢查的input值為空,提醒用戶check_pass = false;$(".reg_frm #" + key).parent().parent().find('td:last-child').text("不能為空");}}if(!check_pass){return false;}// 通過檢查后var login_name = $.trim($('.reg_frm #login_name').val());var email = $.trim($('.reg_frm #email').val());var password = $.trim($('.reg_frm #password').val());var password2 = $.trim($('.reg_frm #password2').val());var verify_code = $.trim($('.reg_frm #verify_code').val());// 提交前,先將按鈕置為不可點擊$("div.reg_shelter").removeClass("hide");var data = $('#register_frm').serialize();console.log(data);$.post({url: "/app01/register/",data: data,dataType: "json",success: function (response) {console.log(response);if(response.hasOwnProperty("status")){if(response.status=='ok'){//console.log("注冊成功");$("div.register_result").text("注冊成功");setTimeout(function () {$("div.login_reg_frm").addClass("hide");$("div.shelter").addClass("hide");}, 2000);}else{$("div.reg_shelter").addClass("hide");$("div.register_result").text(response.msg);}}else{var ul = document.createElement('ul');for(var key in response){var li = document.createElement('li');li.innerText = response[key][0].message;ul.appendChild(li);}$("div.register_result").html(ul.outerHTML);$("div.reg_shelter").addClass("hide");}},error: function (xhr) {$("div.reg_shelter").addClass("hide");}});reload_verify_code(); // 無論結果如何,都刷新驗證碼 }/* 檢查兩次密碼是否一致 */ function confirm_password() {if($('.reg_frm #password').val()!=$('#password2').val()){$('.reg_frm #password2').parent().parent().find('td:last-child').text("兩次密碼不一致");}else{$('.reg_frm #password').parent().parent().find('td:last-child').text("√");$('.reg_frm #password2').parent().parent().find('td:last-child').text("√");} }/* 創建驗證碼圖片標簽 */ function create_verify_code_img() {// 創建驗證碼圖片標簽,插入到驗證碼輸入框后面if(!document.getElementById('verify_code_img')){var img = document.createElement('img');img.id = 'verify_code_img';img.src = '/app01/verify_code/';img.className = 'verify_code';img.onclick = reload_verify_code;$("input.verify_code").after(img);} }/* 刷新驗證碼函數 */ function reload_verify_code() {var img = $('img.verify_code')[0];img.src += '?'; }/* 顯示登錄、注冊頁面 */ function show_login_reg_frm() {$("div.login_reg_frm").removeClass("hide");$("div.shelter").removeClass("hide"); }/* 用戶下拉菜單顯示開關 */ function show_user_menu(flag) {if(flag){$("div.user_menu").removeClass("hide");}else{$("div.user_menu").addClass("hide");} }/* 登錄 */ function login() {var login_name = $(".login_frm input.login_name").val();var password = $(".login_frm input.password").val();$.post({url: '/app01/login/',data: {'login_name': login_name, 'password': password},dataType: "json",success: function (response) {if(response.status=='ok'){// 登錄成功,讀取用戶昵稱和頭像$("div.login_result").text("登錄成功");var display_name = response.display_name;var head_pic = response.head_pic;$("span#display_name").text(display_name);$("img.head_pic").attr("src", head_pic);$("div.login_reg_frm").addClass("hide");$("div.shelter").addClass("hide");$(".user_info #display_name").attr("is_login", "");$(".user_info").removeClass("hide");$(".login_or_register").addClass("hide");get_online_users();}else{$("div.login_result").text(response.error);}},error: function (xhr) {}}); }/* 注銷 */ function logout() {$.get({url: "/app01/logout/",dataType: "json",success:function (response) {if(response.status=='ok'){window.location.href="/app01/";}}}) }/* 檢查是否登錄 */ function is_login() {return document.getElementById('display_name').hasAttribute('is_login'); }/* 隱藏登錄框 */ function close_login_reg_frm() {$("div.login_reg_frm").addClass("hide");$("div.shelter").addClass("hide"); } part1: 實現登錄注冊功能 // 第二部分:實現發布帖子功能 /* 展示發布框 */ function show_publish_frm(flag) {if(!is_login()){show_login_reg_frm();return false;}if(flag){$("div.shelter").removeClass("hide");$("div.publish_frm").removeClass("hide");}else{$("div.shelter").addClass("hide");$("div.publish_frm").addClass("hide");} }function clear_publish_form() {$("textarea.publish_text").val("");$(".publish_frm a.current").removeClass("current");$("#fo")[0].reset();$("div.uploaded_preview").children().remove();}function publish() {var data = {};data['pub_text'] = $.trim($("textarea.publish_text").val());// 檢查文本內容是否為空if(data['pub_text'].length==0){alert("文字內容不能為空。");return false;}// 檢查是否有選擇類別data['catalog'] = $("div.publish_catalog a.current").attr("cid");if(!data['catalog']){alert("請選擇一個分類");return false;}// 獲取圖片var img = $("div.uploaded_preview img")[0];if(img){data['img_link'] = $(img).attr("src");}$.post({url:"/app01/publish/",data: data,dataType: "json",success: function (response) {if(response.status=='ok'){alert("發布成功!");clear_publish_form();show_publish_frm(false);$("div.shelter").addClass("hide");}},error: function (xhr) {}}); }function upload_img() {document.getElementById('if').οnlοad=callback;document.getElementById('fo').submit(); }/* 上傳完畢后的回調函數 */ function callback() {var t = $("#if").contents().find('body').text();var result = JSON.parse(t);console.log(result);if(result.status=='ok'){var a = document.createElement('a');a.href = result.link;a.target = '_blank';var img = document.createElement('img');img.src = result.link;a.appendChild(img);$("div.uploaded_preview").html(a.outerHTML);} }function get_online_users() {if(is_login()){var online_users_container = $("div.online_users_container");// 清理工作 online_users_container.children().remove();online_users_container.text("");// 獲取在線用戶 $.get({url:"/app01/get_online_users/",dataType:"json",success:function (response) {if(response.status=='ok'){console.log(response);var users = response.data;online_users_container.text("在線用戶列表:");for(var key in users){var user_a = document.createElement('a');user_a.innerText=users[key]['display_name'];user_a.setAttribute("user_id", users[key]['id']);user_a.href = "javascript:void(0);";online_users_container.append(user_a);}}}});}} prt2: 實現發布帖子功能 // 第三部分:將帖子展示到頁面,點贊 function create_post_list(posts, cls) {if(posts.length>0){var big_div = document.createElement('div');big_div.className = cls;for(var i=0;i<posts.length;i++){var post_div = document.createElement('div'); // 包裹著整個帖子的divpost_div.className="post_container clearfix";post_div.setAttribute("post_id", posts[i].id);var left_div = document.createElement('div');left_div.className="left_container fl";var right_div = document.createElement('div');right_div.className="right_container fl";var content_div = document.createElement('div');content_div.className="post_content";var bar_div = document.createElement('div');bar_div.className="post_bar";var comment_div = document.createElement('div');comment_div.className="comment_container hide";content_div.innerText = posts[i].content;var like = posts[i].like?"已贊":"贊";var like_a = document.createElement('a');var comment_a = document.createElement('a');var displayname_span = document.createElement("span");var create_i = document.createElement('i');like_a.href = comment_a.href = "javascript:void(0);";like_a.className="like_btn";like_a.setAttribute("onclick", "like(this," + posts[i].id + ")");like_a.setAttribute("like_count", posts[i].like_count);like_a.innerText = like+ '(' + posts[i].like_count + ')';comment_a.className="show_comments_btn";comment_a.setAttribute("onclick", "show_comments(this,"+ posts[i].id +")");comment_a.innerText = '評('+posts[i].comment_count+')';displayname_span.innerText = posts[i].user__display_name;create_i.innerText='在 '+posts[i].create_on+' 發布';bar_div.appendChild(like_a);bar_div.appendChild(comment_a);bar_div.appendChild(displayname_span);bar_div.appendChild(create_i);// comment_div.innerText = "這里是評論";var comment_text_container = document.createElement('div');var comment_content_container = document.createElement('div');comment_text_container.className="comment_text_container";comment_content_container.className="comment_content_container";comment_div.appendChild(comment_text_container);comment_div.appendChild(comment_content_container);left_div.appendChild(content_div);left_div.appendChild(bar_div);if(posts[i].hasOwnProperty("img_link")){var img = document.createElement('img');img.src = posts[i].img_link;right_div.appendChild(img);}var row_container = document.createElement('div');row_container.className="row_container clearfix";row_container.appendChild(left_div);row_container.appendChild(right_div);post_div.appendChild(row_container);post_div.appendChild(comment_div);big_div.appendChild(post_div);}$("div.post_list").append(big_div);} }function view_posts(ele, catalog, page) {$(ele).siblings('a').removeClass("current");$(ele).addClass("current");$("div.paginator").children().remove();$.get({url:"/app01/posts/",data:{"catalog":catalog, "page":page},dataType:"json",success:function (response) {if(response.status=='ok'){// 服務器返回數據// console.log(response);var posts = response['data']['posts'];var current_page = response['data']['current_page'];var page_count = response['data']['page_count'];if(posts.length>0){// 有帖子數據// 區分置頂和普通帖子var top_post_list = [];var normal_post_list = [];for(var key in posts){var post = posts[key];if(post.top){// 帖子有置頂屬性if(post.catalog_id==response['data']['current_catalog']){// 帖子是當前類別post.content = '【置頂】'+ post.content;top_post_list.push(post);}else{// 推入非置頂帖子 normal_post_list.push(post);}}else{// 非置頂帖子 normal_post_list.push(post);}}// 分好之后交給對應的函數處理$("div.post_list").html("");create_post_list(top_post_list,"top_posts");create_post_list(normal_post_list,"normal_posts");create_paginator(page_count, current_page);}else {// 沒有帖子$("div.post_list").text("還沒有帖子喲,要不你發一個:)");}}}}); }/* 分頁 */ function create_paginator(total, current) {if(total>0){var paginator_container = $("div.paginator");paginator_container.children().remove();for(var i=1;i<=total;i++){var a = document.createElement('a');a.innerText=i;if(i==current) a.className="current";a.href="javascript:void(0);";var cid = $("div.nav a.current").attr("cid");a.setAttribute("onclick", "view_posts(this,"+cid+","+i+")");paginator_container.append(a);}} } part3: 將帖子展示到頁面,點贊 // 第四部分:創建和提交、層級評論 /* 點贊 */ function like(ele, post_id) {if(!is_login()){show_login_reg_frm();return false;}$.get({url:"/app01/like_post/",data:{'post':post_id},dataType:"json",success: function (response) {console.log(response);if(response.status="ok"){var like_count = parseInt($(ele).attr("like_count"));if(response.msg=='liked'){// 已贊alert("已贊");like_count++;$(ele).text("已贊("+like_count+")");}else if(response.msg=='unliked'){// 已取消贊alert("已取消贊");like_count--;$(ele).text("贊("+like_count+")");}$(ele).attr("like_count", like_count);}}}); }/* 獲取指定帖子的評論 */ function get_comments(post_id) {var comments;$.get({url:"/app01/get_comments/",data:{"post": post_id},dataType: "json",async: false,success:function (response) {if(response.status=='ok'){comments = response['data'];}}});return comments; }/* 展示該帖子的所有評論 */ function show_comments(ele, post_id) {// 先隱藏所有帖子的評論div,然后展示用戶點擊的帖子的評論div$("div.comment_container").addClass("hide");var current_comment_container = $(ele).parent().parent().parent().siblings(".comment_container").removeClass("hide");// 插入一個textareavar comment_text_container = current_comment_container.children(".comment_text_container");//console.log(comment_text_container); comment_text_container.children().remove();var comment_text = document.createElement('textarea');comment_text.className = "comment_text";comment_text_container.append(comment_text);var send_btn = document.createElement('a');send_btn.className="send_btn";send_btn.innerText = "發送";send_btn.href = "javascript:void(0)";send_btn.setAttribute("onclick", "post_comment(this,"+post_id+")");comment_text_container.append(send_btn);// 獲取這個帖子的所有評論var posts = get_comments(post_id);var comment_content_container = current_comment_container.find(".comment_content_container")[0];build_comment_tree(posts,comment_content_container); }/* 創建評論的HTML */ function build_comment_tree(posts, comment_content_container) {if(posts.length>0){// 先進行清理工作 $(comment_content_container).text("").children().remove();// 添加一個根ulvar root_ul = document.createElement('ul');comment_content_container.appendChild(root_ul);// 循環每個帖子for(var key in posts){// 生成一個li節點,帶comment_id,該li中也帶一個ul用于存放子評論var li = document.createElement('li');li.setAttribute("comment_id", posts[key]['id']);li.setAttribute("display_name", posts[key]['user__display_name']);li.setAttribute("user_id", posts[key]['user_id']);// li的內容var comment_content_div = document.createElement('div'); // 評論的具體內容comment_content_div.className="comment_content_div";comment_content_div.setAttribute("onmouseover","show_reply_btn(this,true)");comment_content_div.setAttribute("onmouseout","show_reply_btn(this,false)");var display_name = posts[key]['user__display_name']==$("div.user_info #display_name").text() ? "我" : posts[key]['user__display_name'];comment_content_div.innerText = display_name +": " +posts[key]['content']+"  "+posts[key]['create_on'];var comment_bar = document.createElement('div'); // 針對該評論的工具欄var reply_a = document.createElement('a');reply_a.className="reply_btn hide";reply_a.innerText = "回復";reply_a.href = "javascript:void(0);";reply_a.setAttribute("onclick", "reply("+posts[key]['id']+",this)");//comment_bar.appendChild(reply_a);comment_content_div.innerHTML += reply_a.outerHTML;var comment_row = document.createElement('div'); // 一條評論的div,包括了以上兩個divcomment_row.className="comment_row";comment_row.appendChild(comment_content_div);comment_row.appendChild(comment_bar);li.appendChild(comment_row); // 將整條評論+工具添加到li中// 用于存放子評論的ul,下方可以沒有任何子評論var sub_ul = document.createElement('ul');li.appendChild(sub_ul);if(posts[key]['reply_to']){// 評論有reply_to$(comment_content_container).find("li[comment_id="+posts[key]['reply_to']+"]").children("ul").append(li);}else {// 評論沒有reply_to,將li加到根部的ul root_ul.appendChild(li);}}}else{$(comment_content_container).text("暫時還沒有評論");} }/**/ function show_reply_btn(ele,show) {show?$(ele).find(".reply_btn:first").removeClass("hide"):$(ele).find(".reply_btn:first").addClass("hide") }/* 提交評論的內容 */ function post_comment(ele, post_id) {var comment_obj = {};comment_obj['post']=post_id;var ta = $(ele).siblings('textarea');comment_obj['comment_text'] = $.trim(ta.val());if(comment_obj['comment_text'].length==0){alert("請輸入評論內容再提交");return false;}var reply_to = $(ele).siblings('textarea').attr("reply_to");if(reply_to){comment_obj['reply_to'] = reply_to}// ajax上傳評論 $.post({url:"/app01/post_comment/",data:comment_obj,dataType:"json",success:function (response) {if(response.status=='ok'){// 評論成功alert("評論成功");var show_comments_btn = $(ele).parent().parent().parent().find('.show_comments_btn')[0];show_comments(show_comments_btn, post_id)}}}); }//點擊某個評論的回復按鈕后,修改textarea的comment_id屬性并讓其得到焦點 function reply(comment_id, ele) {if(!is_login()){show_login_reg_frm();return false;}var reply_to_user = $(ele).parent().parent().parent().attr("display_name");$("textarea.comment_text").val("").attr("reply_to",comment_id).attr("placeholder","回復 "+reply_to_user).focus(); } part4: 創建和提交、層級評論

?

轉載于:https://www.cnblogs.com/xiaonq/p/8213735.html

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的01: 实现注册登录功能的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产中文字幕在线看 | a久久久久 | 久久久久久久久久久久久国产精品 | 91精品国产91久久久久福利 | 久热免费在线 | 2021国产视频| 久久久久这里只有精品 | 国产麻豆精品一区 | 久久久久久影视 | 久久综合九色综合欧美狠狠 | 亚洲无人区小视频 | 成年人电影免费在线观看 | 久久手机精品视频 | 涩涩网站在线看 | 日韩欧美国产免费播放 | 国产三级av在线 | 久久天天操| 四虎8848免费高清在线观看 | 夜夜夜精品| 欧美a级一区二区 | 国产高清av在线播放 | 亚洲精品乱码久久久一二三 | 99精品久久久久 | 国产中文字幕在线 | 在线小视频 | 最近2019好看的中文字幕免费 | 曰韩精品 | 精品国产一二区 | 婷婷在线视频观看 | 99这里有精品 | 51精品国自产在线 | 2019中文字幕第一页 | 黄色毛片大全 | 97国产精品亚洲精品 | 中文字幕 在线 一 二 | 日三级在线 | av性网站| 三上悠亚一区二区在线观看 | 亚洲综合精品在线 | 亚洲国产av精品毛片鲁大师 | 欧美视频18 | 日日干,天天干 | 久久九九久久九九 | 欧美一级电影在线观看 | 国产麻豆精品在线观看 | 97人人模人人爽人人喊网 | 久久精品国产久精国产 | 久久综合九色 | 在线观看免费视频你懂的 | 狠狠躁日日躁夜夜躁av | 国产日韩欧美在线看 | 国内外成人在线视频 | 色婷婷综合久久久久中文字幕1 | 蜜桃久久久 | 少妇性aaaaaaaaa视频 | 日韩精品播放 | av久久在线 | 日韩免费专区 | adc在线观看 | 2023av在线 | 91污视频在线 | 色欧美综合 | 中文字幕 国产 一区 | 久久综合免费 | 婷婷中文字幕在线观看 | 黄色精品免费 | 色夜影院 | 精品国产乱码久久 | 少妇bbbb | 人人插人人艹 | 亚洲日本欧美在线 | 久久人人97超碰精品888 | 欧美一级艳片视频免费观看 | 深夜视频久久 | 一区二区视频欧美 | 91在线视频观看免费 | 91av国产视频| 天天插伊人 | 国产精品乱码久久 | www色,com | 五月婷婷综合在线视频 | 国产色拍拍拍拍在线精品 | 久久久久久久久久伊人 | 中文字幕在线观看视频一区二区三区 | 91在线小视频 | 狠狠躁日日躁夜夜躁av | 成人在线视频免费看 | 麻豆视频国产 | 丁香六月婷婷综合 | 国产高清一区二区 | 黄色一级免费网站 | 日女人电影| 中文在线a天堂 | 五月天色婷婷丁香 | 久久久久久综合网天天 | 中文字幕刺激在线 | 91在线视频导航 | 99视频国产精品免费观看 | 亚洲精品 在线视频 | 在线亚洲免费视频 | 国产亚洲精品久久久久久移动网络 | 久久不卡免费视频 | 国产青青青 | 91高清视频 | 九九在线视频 | 天天夜夜狠狠操 | 久久精品91久久久久久再现 | 国产精品一区在线播放 | 波多野结衣视频一区二区三区 | 欧美精品一区在线 | 国产精品第一页在线 | 极品美女被弄高潮视频网站 | 国产生活一级片 | 天天综合人人 | 国产91在线看 | 精品久久一区二区 | 国产精品永久久久久久久久久 | 最近最新中文字幕 | 亚洲激精日韩激精欧美精品 | 精品亚洲欧美一区 | av网站播放 | 国产成人一区二区三区免费看 | 成人性生爱a∨ | 美女视频是黄的免费观看 | 综合色狠狠 | 中文字幕免费高清在线 | 国产精品中文字幕av | 麻豆精品视频在线观看免费 | 久久国产精品一二三区 | 国产美女久久久 | 免费看的黄色 | 欧美激情第十页 | 亚洲全部视频 | 欧美国产精品久久久久久免费 | 91麻豆传媒 | www.国产在线视频 | 性色av一区二区三区在线观看 | 中文字幕日本在线 | 视频在线观看一区 | 美女免费网站 | 国产精品久久99综合免费观看尤物 | 天天爱天天射天天干天天 | 懂色av一区二区三区蜜臀 | 激情欧美一区二区三区 | 国产精品久久久久久久久久久久 | 久青草国产在线 | 日韩黄色av网站 | 国产精品一区久久久久 | 国产黄色观看 | 亚洲国产伊人 | 精品在线视频一区二区三区 | 国内精品毛片 | 久久精品中文字幕少妇 | 国产xx在线 | 天天射天天射天天 | 日本中文一区二区 | 热久久最新地址 | 91手机电影| 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 亚洲国产成人在线播放 | 99久久精品久久久久久清纯 | 九九久久精品 | 中文字幕丝袜一区二区 | 免费亚洲一区二区 | 手机看国产毛片 | 探花视频在线版播放免费观看 | 亚洲午夜精品福利 | 色资源网免费观看视频 | 天天干天天操天天拍 | 日韩免费网站 | 免费高清在线视频一区· | 久久久久久久看片 | 国产香蕉av | 香蕉精品视频在线观看 | 香蕉视频18 | 成人影视免费 | 91九色蝌蚪国产 | 免费观看成人 | 婷婷六月天在线 | 午夜精品三区 | 久久激情小说 | 久久九九久久九九 | 久久免费片 | 成人午夜免费剧场 | 91漂亮少妇露脸在线播放 | 青草视频在线 | 中文字幕一区二区三区视频 | 久久99久久99精品免视看婷婷 | 国产护士在线 | 日韩精品一区二区三区免费观看视频 | 国产又黄又爽无遮挡 | 日韩资源视频 | 婷婷精品国产一区二区三区日韩 | 91福利视频一区 | 国产成人精品日本亚洲999 | 中文字幕一二三区 | 久久一精品 | 天天操天天操天天操 | 成人网页在线免费观看 | 成年人av在线播放 | 日韩欧美一区二区在线 | 91麻豆精品国产 | 日韩欧美aaa | 麻豆系列在线观看 | 人人射 | 久久艹在线 | 成人在线一区二区三区 | 奇米影视8888 | 日韩草比 | 日批视频在线观看免费 | 婷婷六月天天 | 黄污网站在线观看 | 欧美91成人网 | 五月天丁香综合 | 婷婷亚洲五月色综合 | 久久少妇av | 国产一区二区三区免费在线观看 | 国产伦精品一区二区三区无广告 | 国产尤物一区二区三区 | 精品国产1区2区3区 国产欧美精品在线观看 | 韩日精品在线 | 亚洲天堂网站视频 | 国产精品a久久 | 亚洲视频免费在线看 | 婷婷丁香激情五月 | 成人午夜av电影 | 精品三级av | 天天操天天干天天爽 | 97视频免费看 | 亚洲国产精品99久久久久久久久 | 五月天丁香综合 | 国产高清网站 | 日韩免费在线看 | 免费男女羞羞的视频网站中文字幕 | 久草在线99 | 精品视频免费久久久看 | 黄色a在线观看 | 97精品在线观看 | 亚洲国产中文字幕在线观看 | 国产中文在线观看 | a黄色影院| 中文字幕在线国产 | 天堂av免费观看 | 国产精品女同一区二区三区久久夜 | 在线播放国产精品 | 亚洲 欧洲 国产 日本 综合 | 亚洲国产丝袜在线观看 | 亚洲精品中文在线观看 | 亚洲伦理电影在线 | www免费| 激情视频免费观看 | 国产精品久久久久久久久久ktv | 四虎在线免费视频 | 精品影院一区二区久久久 | 91大神免费视频 | 国产精品你懂的在线观看 | 久草视频在线免费看 | 精品一区二区三区电影 | 成人免费xxx在线观看 | 亚洲尺码电影av久久 | 色五月色开心色婷婷色丁香 | 在线观看视频福利 | 中文字幕在线观看免费观看 | zzijzzij亚洲成熟少妇 | 美女免费视频一区二区 | 香蕉国产91 | 欧美怡红院 | 亚洲综合色站 | 国产又粗又猛又黄又爽视频 | 日本成址在线观看 | 国产女v资源在线观看 | 婷婷激情在线观看 | 一级c片| 热热热热热色 | 日韩激情一二三区 | 亚洲美女在线一区 | 永久免费的啪啪网站免费观看浪潮 | www.97视频 | 精品999 | 国产精品毛片久久久久久久久久99999999 | 国产精品女人久久久久久 | 亚洲精品国产精品乱码在线观看 | 在线成人欧美 | 日韩欧美第二页 | 成人在线观看影院 | 国产精品一区二区免费视频 | 欧美一区二区日韩一区二区 | 亚洲日本三级 | 黄色福利| 性色xxxxhd| 国产成人精品av久久 | 91精品国产91久久久久福利 | 国产成人三级一区二区在线观看一 | 一区免费观看 | 丁香电影小说免费视频观看 | 久久99视频免费 | 欧美日韩精 | 日韩高清一区二区 | 中文在线中文资源 | 国产精品一区二区av麻豆 | 久久综合9988久久爱 | 欧美在线a视频 | 中文字幕免费在线 | 开心丁香婷婷深爱五月 | 久久色视频 | 国产精品高清免费在线观看 | 日韩午夜小视频 | 中文字幕在线观看一区二区 | 午夜视频在线观看一区 | 午夜电影久久久 | 日韩免费观看一区二区三区 | 国产精品99蜜臀久久不卡二区 | 日韩成人免费在线观看 | 日韩在线观看电影 | 最新日韩电影 | 91av蜜桃| 99精品区 | 中文字幕在线免费播放 | 成人国产一区二区 | 亚洲精品国 | 国产黄色精品视频 | 手机在线日韩视频 | a天堂最新版中文在线地址 久久99久久精品国产 | 亚洲欧美va| 婷婷六月综合亚洲 | 91精品福利在线 | 91亚洲成人 | 日韩电影中文,亚洲精品乱码 | 国产精品久久一区二区三区, | 色国产视频 | 99热这里有| 九九九电影免费看 | 国产精品每日更新 | 激情校园亚洲 | 成人一区在线观看 | 久久国产精品网站 | 精品国自产在线观看 | 国产精品中文 | 狠狠色婷婷丁香六月 | 999久久久久久久久久久 | 亚洲一区免费在线 | 国产999精品久久久久久 | 五月婷婷久久综合 | 欧美俄罗斯性视频 | 91人人澡人人爽人人精品 | 国产成人91 | 特片网久久 | 亚洲国产精品一区二区久久,亚洲午夜 | 超碰97久久 | 亚洲精品中文字幕视频 | 在线亚洲欧美视频 | 国产亚洲视频中文字幕视频 | 91香蕉视频在线下载 | 夜夜躁日日躁狠狠久久88av | 久久99精品久久久久久 | 久久久久亚洲精品成人网小说 | 国产成人久久77777精品 | 美女又爽又黄 | 中文字幕专区高清在线观看 | 国产精品视频久久 | 日本高清中文字幕有码在线 | 91九色精品 | 久草综合在线观看 | 国产一区福利在线 | 欧美日韩亚洲国产一区 | 国产在线观看国语版免费 | 午夜视频不卡 | 91手机在线看片 | 91福利免费 | www.com.日本一级 | 免费观看av网站 | 操操操com| 国产成人精品免高潮在线观看 | 久久综合精品一区 | 99久久er热在这里只有精品66 | 国产精品99久久久久的智能播放 | 亚洲国产精品va在线看黑人动漫 | 国产亚洲精品久久久久久久久久 | 国产日韩三级 | 99久久99久久精品国产片果冰 | 五月婷网站| 日韩v欧美v日本v亚洲v国产v | 97免费中文视频在线观看 | 韩日视频在线 | 黄色在线成人 | 国产精品第72页 | 精品在线视频一区二区三区 | 久久久国产精品亚洲一区 | 亚洲精品乱码白浆高清久久久久久 | 99av国产精品欲麻豆 | 中日韩在线视频 | 91精品视频导航 | 国产一卡在线 | 99久久婷婷国产一区二区三区 | 欧美色图另类 | 超碰在线97观看 | 99免费在线视频观看 | 久久草草热国产精品直播 | 6080yy午夜一二三区久久 | 91精品秘密在线观看 | 中文字幕免费高清 | 国产 日韩 欧美 在线 | 精品国模一区二区三区 | 911国产在线观看 | 丁香国产视频 | 精品一区二区三区香蕉蜜桃 | 国产高清不卡一区二区三区 | 欧美日韩精品在线观看视频 | 欧美成人性网 | 欧美一区二视频在线免费观看 | 看片在线亚洲 | 国产婷婷vvvv激情久 | 国产在线视频资源 | 人人看人人做人人澡 | 四川妇女搡bbbb搡bbbb搡 | 中文字幕永久免费 | 国产精品精品 | 精品三级av | 99精品久久精品一区二区 | 日韩动态视频 | 999视频在线观看 | 麻豆成人精品 | 国产在线观看你懂得 | 久久久久久久久久久网站 | 99精品色 | 一本一本久久aa综合精品 | 精品免费一区二区三区 | 香蕉视频最新网址 | 亚洲精品乱码 | 欧美激情第十页 | 亚洲丝袜一区二区 | 国产看片 色 | 天天操天天操天天操天天操天天操天天操 | 一区二区三区在线电影 | 日日躁夜夜躁aaaaxxxx | 四虎4hu永久免费 | www五月婷婷| 成人免费视频播放 | 天天操操 | 波多野结衣视频一区二区 | 国产精品一区在线观看你懂的 | 人人要人人澡人人爽人人dvd | 在线岛国av | 99久久久免费视频 | 亚洲精品1区2区3区 超碰成人网 | 免费观看成年人视频 | 亚洲综合激情五月 | 麻豆久久久久 | 免费视频久久 | 日本久久高清视频 | 中文国产成人精品久久一 | 最新高清无码专区 | 欧美日韩视频在线一区 | 日日麻批40分钟视频免费观看 | 日韩高清在线看 | 日韩.com| 91精品一区二区三区久久久久久 | 欧美一区二区三区在线看 | 一本一道波多野毛片中文在线 | 一区 二区电影免费在线观看 | 久久视频精品在线 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 精品一区 在线 | 91精品国产欧美一区二区成人 | 毛片.com| 亚洲黄色片 | 黄色毛片一级片 | 999成人免费视频 | 在线视频 91 | 国产精品久久久久免费观看 | 久久 在线 | 国产精品久久久久久久av大片 | 在线免费观看亚洲视频 | 成年人看片网站 | 日韩网站在线免费观看 | 国产精品国产三级国产 | 97操操| 狠狠干夜夜 | 国产一区在线视频播放 | 日韩一区二区久久 | 午夜少妇 | 欧美一进一出抽搐大尺度视频 | 免费在线国产视频 | 精品久久久99 | 极品久久久久 | 成人午夜剧场在线观看 | 欧美色图p | 国产精品自在线拍国产 | 亚洲视频在线看 | 久久久网站| 在线观看激情av | 国产成人1区 | 亚洲欧美激情精品一区二区 | 国产精品毛片久久久 | 四虎国产精品永久在线国在线 | 中文字幕在线观看一区二区三区 | aaa亚洲精品一二三区 | 久久这里精品视频 | 亚洲女在线 | 狠狠狠色丁香婷婷综合久久五月 | 色综合色综合色综合 | 久久免费视频4 | 热久久最新地址 | 成人精品福利 | 在线免费观看av网站 | 天天射综合网站 | 97超碰总站 | 亚洲专区欧美专区 | 欧美十八 | 黄色天堂在线观看 | 国产在线1区 | 国产精品永久免费 | 免费看一级特黄a大片 | 天天操天天能 | 国产最新精品视频 | 超碰公开在线 | 亚洲黄色免费 | 丁香婷婷激情 | 亚洲国产午夜视频 | 免费h精品视频在线播放 | 色天堂在线视频 | 韩国av一区二区三区 | 黄色在线网站噜噜噜 | 手机看片福利 | 亚洲少妇自拍 | 日韩在线视频网站 | 久久短视频 | 在线观看精品黄av片免费 | 国产免费一区二区三区最新 | 日韩在线观看你懂得 | 日韩成人免费电影 | 国产成本人视频在线观看 | 日韩专区在线 | 国产亚洲精品久久久久久久久久 | 久久99视频免费观看 | 成人一区二区在线 | 亚洲视频 中文字幕 | 狠狠色噜噜狠狠 | 欧美动漫一区二区三区 | 国产一级二级三级在线观看 | 特级毛片网站 | 韩日三级av| 久久香蕉国产精品麻豆粉嫩av | 国产成人免费av电影 | 91av国产视频| 在线视频1卡二卡三卡 | 亚洲区精品视频 | 97色在线观看 | 欧美 日韩精品 | 婷婷色站 | 久久99这里只有精品 | 91视频3p| 国产精品久久久精品 | 亚洲精品大片www | 亚洲专区欧美专区 | 国产精品久久久久久五月尺 | 亚洲精品国偷拍自产在线观看蜜桃 | 手机色站 | www毛片com| 麻豆传媒视频在线免费观看 | 九九九九九精品 | 狠狠干天天射 | 久久精品99国产 | av九九 | 波多野结衣视频在线 | 在线观看片 | 久久影视精品 | 日韩三级视频在线看 | 国产成人精品午夜在线播放 | 欧美一级日韩免费不卡 | 手机在线看片日韩 | 国产精品福利av | 成人av一区二区三区 | 日韩特黄一级欧美毛片特黄 | 日韩av快播电影网 | 成人免费电影 | 丁香婷婷成人 | 国产精品系列在线观看 | 亚洲精品国产精品国自产在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 人人干人人搞 | 91精品国产成人www | 久草在线视频看看 | 欧美精品久久久久久久久久白贞 | www.成人精品| 日韩欧美国产激情在线播放 | 在线播放日韩av | 亚州精品国产 | 一区二区三区动漫 | 伊人六月 | 日韩成人精品一区二区 | 亚洲成人资源在线 | 黄色三级视频片 | 日本公妇在线观看高清 | 日韩综合一区二区 | 99r在线精品 | 九九九九九精品 | 91成人免费视频 | 久久国产亚洲精品 | 亚洲日本国产精品 | 亚洲男女精品 | 91麻豆精品国产91久久久无限制版 | 久久精品99国产精品亚洲最刺激 | 黄色片视频免费 | 日韩免费在线观看视频 | 国产精品一区二区三区在线播放 | 亚洲最大在线视频 | 在线v片免费观看视频 | 奇人奇案qvod| 国产精品一区在线观看 | 日韩色av色资源 | 黄网站a | 丁香激情综合久久伊人久久 | 天天插伊人 | 小草av在线播放 | 国产福利小视频在线 | 久久久久久久久久久久亚洲 | 六月丁香色婷婷 | 亚洲网站在线 | 深爱开心激情 | 超碰个人在线 | 中文久草| 在线不卡a| 国产精品毛片一区二区在线看 | 99精品久久久久久久 | av一区二区三区在线观看 | 一区二区理论片 | 久久视频这里有久久精品视频11 | 新版资源中文在线观看 | 欧美日韩久久一区 | 91免费网址 | 久久久久久久久久久久久久电影 | 久久久精品国产一区二区电影四季 | 五月婷婷一区二区三区 | 五月婷婷一级片 | 一区二区不卡在线观看 | 97av在线视频 | 中文字幕免费一区 | 欧美极品一区二区三区 | 中文字幕在线成人 | 高清av免费看 | 精品一区二区在线免费观看 | 超碰在线国产 | 亚洲第一成网站 | 9在线观看免费高清完整 | 亚州精品天堂中文字幕 | 亚洲精品白浆高清久久久久久 | www.在线观看av| 国产网站在线免费观看 | 99性视频 | 日日干,天天干 | 久久国产精品免费观看 | 在线免费黄色片 | 精品久久久久久久久久久久久久久久久久 | 亚洲五月婷 | 天天拍天天爽 | 国产精品一区二区久久精品爱微奶 | 久久中文欧美 | 亚洲欧洲久久久 | 中文字幕资源网在线观看 | 国产精品免费在线观看视频 | 国产区久久| .精品久久久麻豆国产精品 亚洲va欧美 | 欧美精品一区二区在线观看 | 久久久免费在线观看 | 久久免费播放视频 | 免费看日韩片 | 黄色国产成人 | 国产精品久久嫩一区二区免费 | 欧美精品九九99久久 | 久久久国产网站 | 亚洲一二区精品 | 免费看v片 | 久热这里有精品 | 久草视频在线资源站 | 色99视频| 亚洲精品久久视频 | 国产精品国产三级国产专区53 | 国产精品99久久免费黑人 | 91桃色视频| 国产精品18p| 成人高清av在线 | 婷婷五月色综合 | 国产视频在线观看一区 | 久久99久久99精品免费看小说 | 国产小视频在线免费观看视频 | 91福利小视频| 亚洲精品黄 | av黄色亚洲| 88av网站 | 免费色视频在线 | 亚洲激情 欧美激情 | 日韩av中文 | 精品久久1 | 精品一二区 | 国产美女精品视频 | 国产视频美女 | 亚洲一级二级三级 | 日韩在线观看你懂的 | 麻豆视频一区二区 | 日韩精品中文字幕一区二区 | 首页中文字幕 | 欧美中文字幕第一页 | 最近中文字幕mv | 国产福利av在线 | 国产日韩欧美精品在线观看 | 亚洲毛片在线观看. | av免费网页 | 国产精品久久久久久99 | 免费看污污视频的网站 | 久久99日韩 | 少妇超碰在线 | 91在线视频网址 | 国产 在线 日韩 | 日韩欧美在线不卡 | 国产成人在线免费观看 | 国产麻豆精品一区二区 | 国产一区二区播放 | 亚洲成人在线免费 | 婷婷五情天综123 | 综合网伊人 | 日韩视频a | 日韩久久精品一区二区三区下载 | 欧美在线久久 | 草久久av| 探花系列在线 | 久久成人免费 | 国产丝袜制服在线 | 成人h在线播放 | 97人人模人人爽人人少妇 | www.人人干| 亚洲三级av | 国产自产在线视频 | 香蕉在线观看 | 国产亚洲精品久久久久5区 成人h电影在线观看 | a天堂最新版中文在线地址 久久99久久精品国产 | av黄色免费网站 | 日韩视频免费播放 | 91精品国产九九九久久久亚洲 | 欧美aa一级 | 在线不卡中文字幕播放 | 国产黄色网 | 黄色片免费在线 | 日日干日日 | 国产精品淫片 | 黄色一二级片 | 99热在线观看 | 99国产精品 | 国产精品久久免费看 | 久久精品国产99 | 免费看的黄色小视频 | 亚洲男男gaygay无套 | 五月婷婷综合久久 | 免费av小说| 麻豆视频在线免费看 | 久久综合五月 | 中文字幕精品一区二区精品 | 激情综合一区 | 在线亚洲天堂网 | 美女搞黄国产视频网站 | 香蕉影院在线 | 视色网站 | 91精品国产高清自在线观看 | 成人影音在线 | 91日韩在线视频 | 成年人网站免费在线观看 | 免费黄av | 国产精品美女久久久久久久久 | 国产一级片网站 | 色综合夜色一区 | 日韩高清在线不卡 | 国产精品久久婷婷六月丁香 | 久久99精品久久只有精品 | 高潮久久久久久 | 国产麻豆精品一区二区 | 亚洲精品在线免费观看视频 | 久草视频免费观 | 国产精品中文在线 | 天天射综合网站 | 玖玖综合网 | 精品人人爽 | 夜夜澡人模人人添人人看 | 国产色网| 久久久久久久久久电影 | 欧美一二三专区 | 91视频免费 | 国产精品999久久久 久产久精国产品 | 成人小视频在线免费观看 | 日本黄色a级大片 | 亚洲日本成人网 | 天天草夜夜 | 日韩高清网站 | 91豆麻精品91久久久久久 | 丁香婷婷成人 | 免费91麻豆精品国产自产在线观看 | 最近中文字幕大全中文字幕免费 | 久草综合视频 | 久久精品一二区 | 日本视频久久久 | 国产精彩视频 | 九九免费在线观看视频 | 激情欧美一区二区三区 | 91在线视频免费 | 国产精品免费久久久久久 | 久久国产精品偷 | 69久久夜色精品国产69 | 天天射天天干天天操 | 日韩av片免费在线观看 | 亚洲午夜久久久久久久久久久 | 五月激情丁香图片 | 久久久国产视频 | 在线观看一区 | 国产黄色观看 | 国产精品1区2区3区在线观看 | 中文字幕一区二区三区久久蜜桃 | 国产精品久久久亚洲 | 成人午夜网址 | 在线成人免费 | a在线观看免费视频 | 国产九九九视频 | 99久久影院 | 欧美性色黄大片在线观看 | 成人黄色电影免费观看 | 日韩在线视频不卡 | 国产精品成人一区二区 | 国产久草在线 | 在线观看精品黄av片免费 | 日韩电影在线观看一区二区三区 | 国产美女视频一区 | 日韩黄色中文字幕 | 六月婷婷久香在线视频 | 久久久影院一区二区三区 | 91久久久久久久一区二区 | 香蕉视频久久久 | 久久欧美精品 | 亚洲欧洲精品视频 | 丁香六月婷婷 | 超碰97国产 | 精品免费视频 | 欧美日韩后 | 精品在线视频播放 | 国产对白av| 精品不卡av | 亚洲精品毛片一级91精品 | 夜夜夜精品 | 国产一级二级av | 毛片一二区 | 国产美女无遮挡永久免费 | 66av99精品福利视频在线 | 黄色录像av | 欧美日韩二区三区 | 天干啦夜天干天干在线线 | 日韩精品一区二区免费视频 | 毛片1000部免费看 | 亚洲第一av在线 | 中文字幕乱码日本亚洲一区二区 | 97精品视频在线播放 | 久久99免费观看 | 99精品系列 | 国产精品一区二区av麻豆 | 天天色影院 | 九九久久久久99精品 | 国产一区二区三精品久久久无广告 | 国产精品一区二区免费看 | 久久在线免费 | av一区二区在线观看中文字幕 | 成人国产在线 | 天天综合导航 | 国产99久久九九精品免费 | 丁香六月在线 | 日韩 在线 | 久久公开视频 | 干天天 | 国产原创在线观看 | 人人插人人爱 | 96精品高清视频在线观看软件特色 | 国产亚洲欧美精品久久久久久 | 欧美日韩精品网站 | 91精品国产麻豆国产自产影视 | 亚洲精品va| 亚洲日日日 | 国产色爽 | 日本久久久久久科技有限公司 | 99自拍视频在线观看 | 亚洲国产日韩一区 | 一区二区丝袜 | 久久精品欧美一区 | 日本中文字幕免费观看 | 亚洲国产日韩一区 | 97国产精品免费 | 欧美日韩中文字幕视频 | 久久99精品国产一区二区三区 | 国产精品初高中精品久久 | 男女啪啪免费网站 | 激情婷婷丁香 | 97香蕉超级碰碰久久免费软件 | 日日爽日日操 | 五月婷婷综合网 | 免费的国产精品 | 麻豆传媒视频观看 | 亚洲精品午夜国产va久久成人 | 久久久久女人精品毛片九一 | 激情综合网五月激情 | 久久人人97超碰com | 色综合天天狠天天透天天伊人 | 久久精品永久免费 | 在线观看中文字幕一区二区 | 国产日韩欧美中文 | 国产在线观看二区 | 成人久久毛片 | 中文字幕文字幕一区二区 | 日本久久精品视频 | 97视频网站 | 日韩性久久 | 亚洲人天堂 | 欧美性生活一级片 | 亚洲国产精品视频在线观看 | 久久久综合九色合综国产精品 | 99电影| 四虎国产视频 | 婷婷丁香五 | 国产91精品一区二区绿帽 | 亚洲天堂精品视频 | www久久99| 精品久久久免费视频 | 天天综合网 天天综合色 | 亚洲黑丝少妇 | 日韩一二三在线 | 精品国产免费观看 | 一级做a视频 | 国产玖玖精品视频 | 欧美在线视频一区二区 | 久久69精品久久久久久久电影好 | 亚洲日本va在线观看 | 国产一级黄色av | 激情五月亚洲 | 91视频久久久久 | 狠狠搞,com | 九九色在线观看 | 日本中文字幕高清 | 超碰日韩在线 | 免费精品人在线二线三线 | 青草视频在线免费 | 久久影院午夜论 | 一区二区三区四区不卡 | 中文在线a天堂 | 91毛片在线 | 激情综合站 | 久久婷综合 | 天天综合色 | 狠狠色噜噜狠狠狠狠 | 天天操天天玩 | 国产视频1区2区3区 久久夜视频 | 亚洲成av片人久久久 | 中文字幕高清在线 | 国产精品第10页 | 欧美a在线免费观看 | 日韩欧美在线国产 | 色噜噜在线观看视频 | 夜色资源网 | 色欧美成人精品a∨在线观看 | 亚洲视频456 | 亚洲www天堂com | 久草在线观看资源 | 国产一区二区在线免费视频 | 天天躁天天操 | 久久五月天综合 | 色久网| 中文字幕第一页在线vr | 国产精品日韩欧美 | 日韩精品一区二区三区视频播放 | 国产精品欧美久久久久天天影视 | 中文字幕第一页在线视频 | 欧美成人性战久久 | 噜噜色官网 | 黄色资源在线 | 欧美精品乱码久久久久 | 天天干天天干天天射 | 久久夜色精品国产欧美乱极品 | 中文字幕亚洲在线观看 | av在线日韩 | 涩涩网站在线播放 | 国产精品剧情在线亚洲 | 在线只有精品 | 日韩在线视频精品 | 欧美激情视频一区 | 成人黄大片视频在线观看 | 成人h在线观看 | 97手机电影网 | 亚州国产精品 | 在线观看久久 | 国产五码一区 | 成人免费看视频 | 精品国产乱码一区二区三区在线 | av在线免费网站 | 国产高清不卡 | 日韩区视频 | 久久艹综合 |