<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    kalman03

    每天早上看一遍《福布斯》富翁排行榜,如果上面沒有我的名字,我就去學習......
    隨筆 - 22, 文章 - 0, 評論 - 86, 引用 - 0
    數據加載中……

    Struts2系列—Form Tags(datetimepicker)

         網絡上關于Struts2方面資料不少,之所以再重復一些關于Struts2的知識,只是因為本人正在學習Struts2,而且在學習的途中也遇見了不少的問題,由于沒有學過Struts2以前的版本,學習途中也是比較的痛苦,在此僅想記錄下我的學習歷程。
         如果你對這個方面有深入研究,懇請你的指點;如果你也是初學者,希望這系列的文章對你有所幫助。

         Struts2中的datetimepicker是一個時間選擇器,個人覺得是一個非常方便的標簽,我們知道用JavaScript代碼實現一個日期選擇器那要寫好長以段代碼,而Struts2內置的這個datetimepicker標簽卻幫我們擺脫了長長的JavaScript的噩夢。來看一下就知道了:

    datetimepicker.jsp:
    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@ taglib prefix="s" uri="/struts-tags"%>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
        
    <s:head theme="simple"/>
        
    <!-- 上面這個head標簽必須要加,至于設置哪種主題沒有限制,根據自己開發的需要 -->
        
    <!-- 當沒有加的時候就沒有顯示,這是為什么?我學習的時候不懂,誰看到了幫我解釋下 -->
        
    <body>
            
    <s:datetimepicker value="today" name="getdate" label="時間選擇器"></s:datetimepicker>
        
    </body>
    </html>
    可以看到很漂亮的效果:


    當然我們可以格式化日期格式,一些其他的處理可以根據需要在action里面進行處理。來看一個初始化時間為2008-08-08,按照年月日顯示的日期選擇器:
    增加下列代碼到上面的JSP里面:
    <s:datetimepicker name="hopedate" label="year-month-date" displayFormat="yyyy-MM-dd" />
    增加一個DatetimepickerAction.java:
    package com.kalman03.action;

    import java.util.Date;

    import com.opensymphony.xwork2.ActionSupport;

    /**
     *@FileName DatetimepickerAction.java
     *
     *@Author kalman03 
     *
     
    */
    public class DatetimepickerAction extends ActionSupport {

        
    private Date hopedate;
        
    public Date getHopedate() {
            
    return hopedate;
        }
        
    public void setHopedate(Date hopedate) {
            
    this.hopedate = hopedate;
        }
        @Override
        
    public String execute() throws Exception {
            
    this.setHopedate(new Date("Aug 08,2008 12:00:00 AM"));
            
    return SUCCESS;
        }
    }
    配置struts.xml里面的映射關系:
    <action name="datetimepickertag" class="com.kalman03.action.DatetimepickerAction">
      
    <result>/datetimepicker.jsp</result>
    </action>
    到此結束可以在瀏覽器輸入:http://localhost:8080/test/datetimepickertag.action得到格式化后的效果:


    我對Struts2的這個標簽無語,太強了,有時間好好看看內部是怎么處理的。在這個我再提供給大家一個JavaScript實現的日期選擇器,需要聲明的是這個JavaScript摘自 kimsoft-jscalendar
    js源碼(支持IE,Firefox,Safari,Opera,谷歌等多瀏覽器):
    <!--
    /**
     * Calendar
     * @param   beginYear           1990
     * @param   endYear             2010
     * @param   language            0(zh_cn)|1(en_us)|2(en_en)|3(zh_tw)
     * @param   patternDelimiter    "-"
     * @param   date2StringPattern  "yyyy-MM-dd"
     * @param   string2DatePattern  "ymd"
     * @version 1.0 build 2006-04-01
     * @version 1.1 build 2006-12-17
     * @author  KimSoft (jinqinghua [at] gmail.com)
     * NOTE!    you can use it free, but keep the copyright please
     * IMPORTANT:you must include this script file inner html body elment 
     * @see http://code.google.com/p/kimsoft-jscalendar/
     
    */
    function Calendar(beginYear, endYear, language, patternDelimiter, date2StringPattern, string2DatePattern) {
        
    this.beginYear = beginYear || 1990;
        
    this.endYear   = endYear   || 2020;
        
    this.language  = language  || 0;
        
    this.patternDelimiter = patternDelimiter     || "-";
        
    this.date2StringPattern = date2StringPattern || Calendar.language["date2StringPattern"][this.language].replace(/\-/g, this.patternDelimiter);
        
    this.string2DatePattern = string2DatePattern || Calendar.language["string2DatePattern"][this.language];
        
        
    this.dateControl = null;
        
    this.panel  = this.getElementById("__calendarPanel");
        
    this.iframe = window.frames["__calendarIframe"];
        
    this.form   = null;
        
        
    this.date = new Date();
        
    this.year = this.date.getFullYear();
        
    this.month = this.date.getMonth();
        
        
    this.colors = {"bg_cur_day":"#00CC33","bg_over":"#EFEFEF","bg_out":"#FFCC00"}
    };

    Calendar.language 
    = {
        
    "year"   : ["\u5e74""""""\u5e74"],
        
    "months" : [
                    [
    "\u4e00\u6708","\u4e8c\u6708","\u4e09\u6708","\u56db\u6708","\u4e94\u6708","\u516d\u6708","\u4e03\u6708","\u516b\u6708","\u4e5d\u6708","\u5341\u6708","\u5341\u4e00\u6708","\u5341\u4e8c\u6708"],
                    [
    "JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"],
                    [
    "JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"],
                    [
    "\u4e00\u6708","\u4e8c\u6708","\u4e09\u6708","\u56db\u6708","\u4e94\u6708","\u516d\u6708","\u4e03\u6708","\u516b\u6708","\u4e5d\u6708","\u5341\u6708","\u5341\u4e00\u6708","\u5341\u4e8c\u6708"]
                    ],
        
    "weeks"  : [["\u65e5","\u4e00","\u4e8c","\u4e09","\u56db","\u4e94","\u516d"],
                    [
    "Sun","Mon","Tur","Wed","Thu","Fri","Sat"],
                    [
    "Sun","Mon","Tur","Wed","Thu","Fri","Sat"],
                    [
    "\u65e5","\u4e00","\u4e8c","\u4e09","\u56db","\u4e94","\u516d"]
            ],
        
    "clear"  : ["\u6e05\u7a7a""Clear""Clear""\u6e05\u7a7a"],
        
    "today"  : ["\u4eca\u5929""Today""Today""\u4eca\u5929"],
        
    "close"  : ["\u5173\u95ed""Close""Close""\u95dc\u9589"],
        
    "date2StringPattern" : ["yyyy-MM-dd""yyyy-MM-dd""yyyy-MM-dd""yyyy-MM-dd"],
        
    "string2DatePattern" : ["ymd","ymd""ymd""ymd"]
    };

    Calendar.prototype.draw 
    = function() {
        calendar 
    = this;
        
        
    var _cs = [];
        _cs[_cs.length] 
    = '<form id="__calendarForm" name="__calendarForm" method="post">';
        _cs[_cs.length] 
    = '<table id="__calendarTable" width="100%" border="0" cellpadding="3" cellspacing="1"
    align
    ="center">';
        _cs[_cs.length] 
    = ' <tr>';
        _cs[_cs.length] 
    = '  <th><input class="l" name="goPrevMonthButton" type="button" id="goPrevMonthButton"
     value
    ="&lt;" \/><\/th>';
        _cs[_cs.length] 
    = '  <th colspan="5"><select class="year" name="yearSelect" id="yearSelect"><\/select><select class="month" name="monthSelect" id="monthSelect"><\/select><\/th>';
        _cs[_cs.length] 
    = '  <th><input class="r" name="goNextMonthButton" type="button" id="goNextMonthButton"
    value
    ="&gt;" \/><\/th>';
        _cs[_cs.length] 
    = ' <\/tr>';
        _cs[_cs.length] 
    = ' <tr>';
        
    for(var i = 0; i < 7; i++) {
            _cs[_cs.length] 
    = '<th class="theader">';
            _cs[_cs.length] 
    = Calendar.language["weeks"][this.language][i];
            _cs[_cs.length] 
    = '<\/th>';    
        }
        _cs[_cs.length] 
    = '<\/tr>';
        
    for(var i = 0; i < 6; i++){
            _cs[_cs.length] 
    = '<tr align="center">';
            
    for(var j = 0; j < 7; j++) {
                
    switch (j) {
                    
    case 0: _cs[_cs.length] = '<td class="sun">&nbsp;<\/td>'; break;
                    
    case 6: _cs[_cs.length] = '<td class="sat">&nbsp;<\/td>'; break;
                    
    default:_cs[_cs.length] = '<td class="normal">&nbsp;<\/td>'; break;
                }
            }
            _cs[_cs.length] 
    = '<\/tr>';
        }
        _cs[_cs.length] 
    = ' <tr>';
        _cs[_cs.length] 
    = '  <th colspan="2"><input type="button" class="b" name="clearButton" id="clearButton" \/><\/th>';
        _cs[_cs.length] 
    = '  <th colspan="3"><input type="button" class="b" name="selectTodayButton" id="selectTodayButton" \/><\/th>';
        _cs[_cs.length] 
    = '  <th colspan="2"><input type="button" class="b" name="closeButton" id="closeButton" \/><\/th>';
        _cs[_cs.length] 
    = ' <\/tr>';
        _cs[_cs.length] 
    = '<\/table>';
        _cs[_cs.length] 
    = '<\/form>';
        
        
    this.iframe.document.body.innerHTML = _cs.join("");
        
    this.form = this.iframe.document.forms["__calendarForm"];

        
    this.form.clearButton.value = Calendar.language["clear"][this.language];
        
    this.form.selectTodayButton.value = Calendar.language["today"][this.language];
        
    this.form.closeButton.value = Calendar.language["close"][this.language];
        
        
    this.form.goPrevMonthButton.onclick = function () {calendar.goPrevMonth(this);}
        
    this.form.goNextMonthButton.onclick = function () {calendar.goNextMonth(this);}
        
    this.form.yearSelect.onchange = function () {calendar.update(this);}
        
    this.form.monthSelect.onchange = function () {calendar.update(this);}
        
        
    this.form.clearButton.onclick = function () {calendar.dateControl.value = "";calendar.hide();}
        
    this.form.closeButton.onclick = function () {calendar.hide();}
        
    this.form.selectTodayButton.onclick = function () {
            
    var today = new Date();
            calendar.date 
    = today;
            calendar.year 
    = today.getFullYear();
            calendar.month 
    = today.getMonth();
            calendar.dateControl.value 
    = today.format(calendar.date2StringPattern);
            calendar.hide();
        }
    };

    Calendar.prototype.bindYear 
    = function() {
        
    var ys = this.form.yearSelect;
        ys.length 
    = 0;
        
    for (var i = this.beginYear; i <= this.endYear; i++){
            ys.options[ys.length] 
    = new Option(i + Calendar.language["year"][this.language], i);
        }
    };

    Calendar.prototype.bindMonth 
    = function() {
        
    var ms = this.form.monthSelect;
        ms.length 
    = 0;
        
    for (var i = 0; i < 12; i++){
            ms.options[ms.length] 
    = new Option(Calendar.language["months"][this.language][i], i);
        }
    };

    Calendar.prototype.goPrevMonth 
    = function(e){
        
    if (this.year == this.beginYear && this.month == 0){return;}
        
    this.month--;
        
    if (this.month == -1) {
            
    this.year--;
            
    this.month = 11;
        }
        
    this.date = new Date(this.year, this.month, 1);
        
    this.changeSelect();
        
    this.bindData();
    };

    Calendar.prototype.goNextMonth 
    = function(e){
        
    if (this.year == this.endYear && this.month == 11){return;}
        
    this.month++;
        
    if (this.month == 12) {
            
    this.year++;
            
    this.month = 0;
        }
        
    this.date = new Date(this.year, this.month, 1);
        
    this.changeSelect();
        
    this.bindData();
    };

    Calendar.prototype.changeSelect 
    = function() {
        
    var ys = this.form.yearSelect;
        
    var ms = this.form.monthSelect;
        
    for (var i= 0; i < ys.length; i++){
            
    if (ys.options[i].value == this.date.getFullYear()){
                ys[i].selected 
    = true;
                
    break;
            }
        }
        
    for (var i= 0; i < ms.length; i++){
            
    if (ms.options[i].value == this.date.getMonth()){
                ms[i].selected 
    = true;
                
    break;
            }
        }
    };

    Calendar.prototype.update 
    = function (e){
        
    this.year  = e.form.yearSelect.options[e.form.yearSelect.selectedIndex].value;
        
    this.month = e.form.monthSelect.options[e.form.monthSelect.selectedIndex].value;
        
    this.date = new Date(this.year, this.month, 1);
        
    this.changeSelect();
        
    this.bindData();
    };

    Calendar.prototype.bindData 
    = function () {
        
    var calendar = this;
        
    var dateArray = this.getMonthViewDateArray(this.date.getFullYear(), this.date.getMonth());
        
    var tds = this.getElementsByTagName("td"this.getElementById("__calendarTable"this.iframe.document));
        
    for(var i = 0; i < tds.length; i++) {
              tds[i].style.backgroundColor 
    = calendar.colors["bg_over"];
            tds[i].onclick 
    = null;
            tds[i].onmouseover 
    = null;
            tds[i].onmouseout 
    = null;
            tds[i].innerHTML 
    = dateArray[i] || "&nbsp;";
            
    if (i > dateArray.length - 1continue;
            
    if (dateArray[i]){
                tds[i].onclick 
    = function () {
                    
    if (calendar.dateControl){
                        calendar.dateControl.value 
    = new Date(calendar.date.getFullYear(),
                                                            calendar.date.getMonth(),
                                                            
    this.innerHTML).format(calendar.date2StringPattern);
                    }
                    calendar.hide();
                }
                tds[i].onmouseover 
    = function () {this.style.backgroundColor = calendar.colors["bg_out"];}
                tds[i].onmouseout  
    = function () {this.style.backgroundColor = calendar.colors["bg_over"];}
                
    var today = new Date();
                
    if (today.getFullYear() == calendar.date.getFullYear()) {
                    
    if (today.getMonth() == calendar.date.getMonth()) {
                        
    if (today.getDate() == dateArray[i]) {
                            tds[i].style.backgroundColor 
    = calendar.colors["bg_cur_day"];
                            tds[i].onmouseover 
    = function () {this.style.backgroundColor = calendar.colors["bg_out"];}
                            tds[i].onmouseout  
    = function () {this.style.backgroundColor = calendar.colors["bg_cur_day"];}
                        }
                    }
                }
            }
    //end if
        }//end for
    };

    Calendar.prototype.getMonthViewDateArray 
    = function (y, m) {
        
    var dateArray = new Array(42);
        
    var dayOfFirstDate = new Date(y, m, 1).getDay();
        
    var dateCountOfMonth = new Date(y, m + 10).getDate();
        
    for (var i = 0; i < dateCountOfMonth; i++) {
            dateArray[i 
    + dayOfFirstDate] = i + 1;
        }
        
    return dateArray;
    };

    Calendar.prototype.show 
    = function (dateControl, popuControl) {
        
    if (this.panel.style.visibility == "visible") {
            
    this.panel.style.visibility = "hidden";
        }
        
    if (!dateControl){
            
    throw new Error("arguments[0] is necessary!")
        }
        
    this.dateControl = dateControl;
        popuControl 
    = popuControl || dateControl;

        
    this.draw();
        
    this.bindYear();
        
    this.bindMonth();
        
    if (dateControl.value.length > 0){
            
    this.date  = new Date(dateControl.value.toDate(this.patternDelimiter, this.string2DatePattern));
            
    this.year  = this.date.getFullYear();
            
    this.month = this.date.getMonth();
        }
        
    this.changeSelect();
        
    this.bindData();

        
    var xy = this.getAbsPoint(popuControl);
        
    this.panel.style.left = xy.x + "px";
        
    this.panel.style.top = (xy.y + dateControl.offsetHeight) + "px";
        
    this.panel.style.visibility = "visible";
    };

    Calendar.prototype.hide 
    = function() {
        
    this.panel.style.visibility = "hidden";
    };

    Calendar.prototype.getElementById 
    = function(id, object){
        object 
    = object || document;
        
    return document.getElementById ? object.getElementById(id) : document.all(id);
    };

    Calendar.prototype.getElementsByTagName 
    = function(tagName, object){
        object 
    = object || document;
        
    return document.getElementsByTagName ? object.getElementsByTagName(tagName) : document.all.tags(tagName);
    };

    Calendar.prototype.getAbsPoint 
    = function (e){
        
    var x = e.offsetLeft;
        
    var y = e.offsetTop;
        
    while(e = e.offsetParent){
            x 
    += e.offsetLeft;
            y 
    += e.offsetTop;
        }
        
    return {"x": x, "y": y};
    };

    /**
     * @param   d the delimiter
     * @param   p the pattern of your date
     * @author  meizz
     * @author  kimsoft add w+ pattern
     
    */
    Date.prototype.format 
    = function(style) {
        
    var o = {
            
    "M+" : this.getMonth() + 1//month
            "d+" : this.getDate(),      //day
            "h+" : this.getHours(),     //hour
            "m+" : this.getMinutes(),   //minute
            "s+" : this.getSeconds(),   //second
            "w+" : "\u65e5\u4e00\u4e8c\u4e09\u56db\u4e94\u516d".charAt(this.getDay()),   //week
            "q+" : Math.floor((this.getMonth() + 3/ 3),  //quarter
            "S"  : this.getMilliseconds() //millisecond
        }
        
    if (/(y+)/.test(style)) {
            style 
    = style.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
        }
        
    for(var k in o){
            
    if (new RegExp("("+ k +")").test(style)){
          style 
    = style.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
            }
        }
        
    return style;
    };

    /**
     * @param d the delimiter
     * @param p the pattern of your date
     * @rebuilder kimsoft
     * @version build 2006.12.15
     
    */
    String.prototype.toDate 
    = function(delimiter, pattern) {
        delimiter 
    = delimiter || "-";
        pattern 
    = pattern || "ymd";
        
    var a = this.split(delimiter);
        
    var y = parseInt(a[pattern.indexOf("y")], 10);
        
    //remember to change this next century ;)
        if(y.toString().length <= 2) y += 2000;
        
    if(isNaN(y)) y = new Date().getFullYear();
        
    var m = parseInt(a[pattern.indexOf("m")], 10- 1;
        
    var d = parseInt(a[pattern.indexOf("d")], 10);
        
    if(isNaN(d)) d = 1;
        
    return new Date(y, m, d);
    };

    document.writeln('
    <div id="__calendarPanel" style="position:absolute;visibility:hidden;z-index:9999;background-color:#FFFFFF;border:1px solid #666666;width:200px;height:216px;">');
    document.writeln('
    <iframe name="__calendarIframe" id="__calendarIframe" width="100%" height="100%"
    scrolling
    ="no" frameborder="0" style="margin:0px;"><\/iframe>');
    var __ci = window.frames['__calendarIframe'];
    __ci.document.writeln('
    <!DOCTYPE html PUBLIC "-\/\/W3C\/\/DTD XHTML 1.0 Transitional\/\/EN" "http:\/\/www.w3.org\/TR\/xhtml1\/DTD\/xhtml1-transitional.dtd">');
    __ci.document.writeln('
    <html xmlns="http:\/\/www.w3.org\/1999\/xhtml">');
    __ci.document.writeln('
    <head>');
    __ci.document.writeln('
    <meta http-equiv="Content-Type" content="text\/html; charset=utf-8" \/>');
    __ci.document.writeln('
    <title>Web Calendar(UTF-8) Written By KimSoft<\/title>');
    __ci.document.writeln('
    <style type="text\/css">');
    __ci.document.writeln('
    <!--');
    __ci.document.writeln('body {font
    -size:12px;margin:0px;text-align:center;}');
    __ci.document.writeln('form {margin:0px;}');
    __ci.document.writeln('select {font
    -size:12px;background-color:#EFEFEF;}');
    __ci.document.writeln('table {border:0px solid #CCCCCC;background
    -color:#FFFFFF}');
    __ci.document.writeln('th {font
    -size:12px;font-weight:normal;background-color:#FFFFFF;}');
    __ci.document.writeln('th.theader {font
    -weight:normal;background-color:#666666;color:#FFFFFF;width:24px;}');
    __ci.document.writeln('select.year {width:64px;}');
    __ci.document.writeln('select.month {width:60px;}');
    __ci.document.writeln('td {font
    -size:12px;text-align:center;}');
    __ci.document.writeln('td.sat {color:#0000FF;background
    -color:#EFEFEF;}');
    __ci.document.writeln('td.sun {color:#FF0000;background
    -color:#EFEFEF;}');
    __ci.document.writeln('td.normal {background
    -color:#EFEFEF;}');
    __ci.document.writeln('input.l {border: 1px solid #CCCCCC;background
    -color:#EFEFEF;width:20px;height:20px;}');
    __ci.document.writeln('input.r {border: 1px solid #CCCCCC;background
    -color:#EFEFEF;width:20px;height:20px;}');
    __ci.document.writeln('input.b {border: 1px solid #CCCCCC;background
    -color:#EFEFEF;width:100%;height:20px;}');
    __ci.document.writeln('
    -->');
    __ci.document.writeln('
    <\/style>');
    __ci.document.writeln('
    <\/head>');
    __ci.document.writeln('
    <body>');
    __ci.document.writeln('
    <\/body>');
    __ci.document.writeln('
    <\/html>');
    __ci.document.close();
    document.writeln('
    <\/div>');
    var calendar = new Calendar();
    //-->
              
    增加一句
     <input name="date" type="text" id="date" onclick="new Calendar().show(this);" size="10"
    maxlength
    ="10"readonly="readonly "/>
    導入上面的JavaScript源碼,效果:




    posted on 2008-10-30 11:27 kalman03 閱讀(4278) 評論(3)  編輯  收藏 所屬分類: Struts2

    評論

    # re: Struts2系列—Form Tags(datetimepicker)[未登錄]  回復  更多評論   

    你這個好像只有在struts2.0版本的才可以,2.0以上的版本好像里面敲不出來s:datetimepicker>標簽吧
    2011-01-06 11:38 | 祥子

    # re: Struts2系列—Form Tags(datetimepicker)  回復  更多評論   

    2.0后 標簽在這里


    <%@ taglib prefix="sdt" uri="/struts-dojo-tags"%>


    <sdt:datetimepicker type="data" />
    2011-01-12 09:11 | amis

    # re: Struts2系列—Form Tags(datetimepicker)  回復  更多評論   

    太給力了,嘿嘿,謝謝!
    2011-04-27 09:26 | 黃鑫泉
    主站蜘蛛池模板: 亚洲人成色77777在线观看大| 亚洲欧美日韩一区二区三区在线| 麻豆国产人免费人成免费视频 | 久久久久久国产精品免费免费男同 | 亚洲国产综合专区在线电影| 成人免费无码大片A毛片抽搐色欲| 国产真人无码作爱免费视频| 麻豆亚洲AV成人无码久久精品 | 特级做A爰片毛片免费看无码| 亚洲日韩在线中文字幕综合 | 在线永久看片免费的视频| 亚洲精品V天堂中文字幕| 97久久精品亚洲中文字幕无码 | 免费精品国自产拍在线播放 | 国产又长又粗又爽免费视频| 国产一卡2卡3卡4卡2021免费观看| 国偷自产一区二区免费视频| 9久热精品免费观看视频| 一个人看www免费高清字幕| 成人亚洲国产精品久久| 亚洲欧美日韩综合久久久| 亚洲国产av美女网站| 久久久久亚洲av无码专区| 亚洲国产精品久久| 亚洲av永久无码精品网站 | aa毛片免费全部播放完整| 一级成人毛片免费观看| 香蕉国产在线观看免费| 特黄aa级毛片免费视频播放| 亚洲JIZZJIZZ妇女| 久久久久亚洲AV无码去区首| 亚洲国产成人精品无码区二本| 国内精品久久久久影院亚洲| 亚洲无mate20pro麻豆| 国产亚洲精品观看91在线| 久久久久亚洲精品天堂久久久久久 | 亚洲精品狼友在线播放| 国产成A人亚洲精V品无码性色 | 久久成人免费电影| 84pao国产成视频免费播放| 人与动性xxxxx免费|