zoukankan      html  css  js  c++  java
  • swfupload 例子

    upload.html
    
     1 <!DOCTYPE html>
     2 <html lang="en">
     3     <head>
     4         <script type='text/javascript' src='swfupload.js'></script>
     5     <link href="default.css" rel="stylesheet" type="text/css" />
     6     <script type="text/javascript" src="js/fileprogress.js"></script>
     7 <script type="text/javascript" src="js/handlers.js"></script>
     8     </head>
     9     <body>
    10         <div id="divSWFUploadUI" style="margin-top: 20px;">
    11             <div class="fieldset  flash" id="fsUploadProgress">
    12             <span class="legend">Upload Queue</span>
    13             </div>
    14                 <div id="SWFUploads">
    15                     <p>
    16                         <span id="SWFUpload"></span>
    17                         <input id="btnCancel" type="button" value="Cancel All Uploads" disabled="disabled" style="margin-left: 2px; height: 22px; font-size: 8pt;" />
    18                         <br />
    19                     </p>
    20                 </div>
    21         <div>
    22             <div id="divLoadingContent" class="content" style="background-color: #FFFF66; border-top: solid 4px #FF9966; border-bottom: solid 4px #FF9966; margin: 10px 25px; padding: 10px 15px; display: none;">
    23                 SWFUpload is loading. Please wait a moment...
    24             </div>
    25             <div id="divLongLoading" class="content" style="background-color: #FFFF66; border-top: solid 4px #FF9966; border-bottom: solid 4px #FF9966; margin: 10px 25px; padding: 10px 15px; display: none;">
    26                 SWFUpload is taking a long time to load or the load has failed.  Please make sure that the Flash Plugin is enabled and that a working version of the Adobe Flash Player is installed.
    27             </div>
    28             <div id="divAlternateContent" class="content" style="background-color: #FFFF66; border-top: solid 4px #FF9966; border-bottom: solid 4px #FF9966; margin: 10px 25px; padding: 10px 15px; display: none;">
    29                 We're sorry.  SWFUpload could not load.  You may need to install or upgrade Flash Player.
    30                 Visit the <a href="http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash">Adobe website</a> to get the Flash Player.
    31             </div>
    32         
    33             <script type='text/javascript'>
    34             var swf;
    35                 var settings={
    36                     upload_url:'upload.php',
    37                     flash_url : "swfupload.swf",
    38                     post_params: {
    39             "PHPSESSID" : "NONE",
    40             "HELLO-WORLD" : "Here I Am",
    41             ".what" : "OKAY"
    42         },
    43         file_size_limit : "1000 MB",
    44         file_types : "*.mp4",
    45         file_upload_limit : 1000,
    46         file_queue_limit : 0,
    47         custom_settings : {
    48             progressTarget : "fsUploadProgress",
    49             cancelButtonId : "btnCancel"
    50         },
    51         debug: false,
    52 
    53         // Button Settings
    54         button_image_url : "XPButtonUploadText_61x22.png",
    55         button_placeholder_id : "SWFUpload",
    56         button_ 61,
    57         button_height: 22,
    58 
    59         // The event handler functions are defined in handlers.js
    60         swfupload_preload_handler : swfUploadPreLoad,
    61         swfupload_load_failed_handler : swfUploadLoadFailed,
    62         swfupload_loaded_handler : swfUploadLoaded,
    63         file_queued_handler : fileQueued,
    64         file_queue_error_handler : fileQueueError,
    65         file_dialog_complete_handler : fileDialogComplete,
    66         upload_start_handler : uploadStart,
    67         upload_progress_handler : uploadProgress,
    68         upload_error_handler : uploadError,
    69         upload_success_handler : uploadSuccess,
    70         upload_complete_handler : uploadComplete,
    71         queue_complete_handler : queueComplete    // Queue plugin event
    72         
    73     };
    74 
    75     swf= new SWFUpload (settings);
    76 </script>
    77     </body>
    78 </html>
    upload.html
    
    
    

    upload.php
    1 <?php
    2 if(!is_dir("./files")) mkdir("./files", 0755); 
    3 move_uploaded_file($_FILES['Filedata']['tmp_name'], "./files/".$_FILES['Filedata']['name']);
    
    handler.js
      1 /* Demo Note:  This demo uses a FileProgress class that handles the UI for displaying the file name and percent complete.
      2 The FileProgress class is not part of SWFUpload.
      3 */
      4 
      5 
      6 /* **********************
      7    Event Handlers
      8    These are my custom event handlers to make my
      9    web application behave the way I went when SWFUpload
     10    completes different tasks.  These aren't part of the SWFUpload
     11    package.  They are part of my application.  Without these none
     12    of the actions SWFUpload makes will show up in my application.
     13    ********************** */
     14 
     15 function swfUploadPreLoad() {
     16     var self = this;
     17     var loading = function () {
     18         //document.getElementById("divSWFUploadUI").style.display = "none";
     19         document.getElementById("divLoadingContent").style.display = "";
     20 
     21         var longLoad = function () {
     22             document.getElementById("divLoadingContent").style.display = "none";
     23             document.getElementById("divLongLoading").style.display = "";
     24         };
     25         this.customSettings.loadingTimeout = setTimeout(function () {
     26                 longLoad.call(self)
     27             },
     28             15 * 1000
     29         );
     30     };
     31     
     32     this.customSettings.loadingTimeout = setTimeout(function () {
     33             loading.call(self);
     34         },
     35         1*1000
     36     );
     37 }
     38 function swfUploadLoaded() {
     39     var self = this;
     40     clearTimeout(this.customSettings.loadingTimeout);
     41     //document.getElementById("divSWFUploadUI").style.visibility = "visible";
     42     //document.getElementById("divSWFUploadUI").style.display = "block";
     43     document.getElementById("divLoadingContent").style.display = "none";
     44     document.getElementById("divLongLoading").style.display = "none";
     45     document.getElementById("divAlternateContent").style.display = "none";
     46     
     47     //document.getElementById("btnBrowse").onclick = function () { self.selectFiles(); };
     48     document.getElementById("btnCancel").onclick = function () { self.cancelQueue(); };
     49 }
     50    
     51 function swfUploadLoadFailed() {
     52     clearTimeout(this.customSettings.loadingTimeout);
     53     //document.getElementById("divSWFUploadUI").style.display = "none";
     54     document.getElementById("divLoadingContent").style.display = "none";
     55     document.getElementById("divLongLoading").style.display = "none";
     56     document.getElementById("divAlternateContent").style.display = "";
     57 }
     58    
     59    
     60 function fileQueued(file) {
     61     try {
     62         var progress = new FileProgress(file, this.customSettings.progressTarget);
     63         progress.setStatus("Pending...");
     64         progress.toggleCancel(true, this);
     65 
     66     } catch (ex) {
     67         this.debug(ex);
     68     }
     69 
     70 }
     71 
     72 function fileQueueError(file, errorCode, message) {
     73     try {
     74         if (errorCode === SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED) {
     75             alert("You have attempted to queue too many files.
    " + (message === 0 ? "You have reached the upload limit." : "You may select " + (message > 1 ? "up to " + message + " files." : "one file.")));
     76             return;
     77         }
     78 
     79         var progress = new FileProgress(file, this.customSettings.progressTarget);
     80         progress.setError();
     81         progress.toggleCancel(false);
     82 
     83         switch (errorCode) {
     84         case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
     85             progress.setStatus("File is too big.");
     86             this.debug("Error Code: File too big, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
     87             break;
     88         case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
     89             progress.setStatus("Cannot upload Zero Byte files.");
     90             this.debug("Error Code: Zero byte file, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
     91             break;
     92         case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
     93             progress.setStatus("Invalid File Type.");
     94             this.debug("Error Code: Invalid File Type, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
     95             break;
     96         default:
     97             if (file !== null) {
     98                 progress.setStatus("Unhandled Error");
     99             }
    100             this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
    101             break;
    102         }
    103     } catch (ex) {
    104         this.debug(ex);
    105     }
    106 }
    107 
    108 function fileDialogComplete(numFilesSelected, numFilesQueued) {
    109     try {
    110         if (numFilesSelected > 0) {
    111             document.getElementById(this.customSettings.cancelButtonId).disabled = false;
    112         }
    113         
    114         /* I want auto start the upload and I can do that here */
    115         this.startUpload();
    116     } catch (ex)  {
    117         this.debug(ex);
    118     }
    119 }
    120 
    121 function uploadStart(file) {
    122     try {
    123         /* I don't want to do any file validation or anything,  I'll just update the UI and
    124         return true to indicate that the upload should start.
    125         It's important to update the UI here because in Linux no uploadProgress events are called. The best
    126         we can do is say we are uploading.
    127          */
    128         var progress = new FileProgress(file, this.customSettings.progressTarget);
    129         progress.setStatus("Uploading...");
    130         progress.toggleCancel(true, this);
    131     }
    132     catch (ex) {}
    133     
    134     return true;
    135 }
    136 
    137 function uploadProgress(file, bytesLoaded, bytesTotal) {
    138     try {
    139         var percent = Math.ceil((bytesLoaded / bytesTotal) * 100);
    140 
    141         var progress = new FileProgress(file, this.customSettings.progressTarget);
    142         progress.setProgress(percent);
    143         progress.setStatus("Uploading...");
    144     } catch (ex) {
    145         this.debug(ex);
    146     }
    147 }
    148 
    149 function uploadSuccess(file, serverData) {
    150     try {
    151         var progress = new FileProgress(file, this.customSettings.progressTarget);
    152         progress.setComplete();
    153         progress.setStatus("Complete.");
    154         progress.toggleCancel(false);
    155 
    156     } catch (ex) {
    157         this.debug(ex);
    158     }
    159 }
    160 
    161 function uploadError(file, errorCode, message) {
    162     try {
    163         var progress = new FileProgress(file, this.customSettings.progressTarget);
    164         progress.setError();
    165         progress.toggleCancel(false);
    166 
    167         switch (errorCode) {
    168         case SWFUpload.UPLOAD_ERROR.HTTP_ERROR:
    169             progress.setStatus("Upload Error: " + message);
    170             this.debug("Error Code: HTTP Error, File name: " + file.name + ", Message: " + message);
    171             break;
    172         case SWFUpload.UPLOAD_ERROR.UPLOAD_FAILED:
    173             progress.setStatus("Upload Failed.");
    174             this.debug("Error Code: Upload Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
    175             break;
    176         case SWFUpload.UPLOAD_ERROR.IO_ERROR:
    177             progress.setStatus("Server (IO) Error");
    178             this.debug("Error Code: IO Error, File name: " + file.name + ", Message: " + message);
    179             break;
    180         case SWFUpload.UPLOAD_ERROR.SECURITY_ERROR:
    181             progress.setStatus("Security Error");
    182             this.debug("Error Code: Security Error, File name: " + file.name + ", Message: " + message);
    183             break;
    184         case SWFUpload.UPLOAD_ERROR.UPLOAD_LIMIT_EXCEEDED:
    185             progress.setStatus("Upload limit exceeded.");
    186             this.debug("Error Code: Upload Limit Exceeded, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
    187             break;
    188         case SWFUpload.UPLOAD_ERROR.FILE_VALIDATION_FAILED:
    189             progress.setStatus("Failed Validation.  Upload skipped.");
    190             this.debug("Error Code: File Validation Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
    191             break;
    192         case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
    193             // If there aren't any files left (they were all cancelled) disable the cancel button
    194             if (this.getStats().files_queued === 0) {
    195                 document.getElementById(this.customSettings.cancelButtonId).disabled = true;
    196             }
    197             progress.setStatus("Cancelled");
    198             progress.setCancelled();
    199             break;
    200         case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
    201             progress.setStatus("Stopped");
    202             break;
    203         default:
    204             progress.setStatus("Unhandled Error: " + errorCode);
    205             this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
    206             break;
    207         }
    208     } catch (ex) {
    209         this.debug(ex);
    210     }
    211 }
    212 
    213 function uploadComplete(file) {
    214     if (this.getStats().files_queued === 0) {
    215         document.getElementById(this.customSettings.cancelButtonId).disabled = true;
    216     }
    217 }
    218 
    219 // This event comes from the Queue Plugin
    220 function queueComplete(numFilesUploaded) {
    221     var status = document.getElementById("divStatus");
    222     status.innerHTML = numFilesUploaded + " file" + (numFilesUploaded === 1 ? "" : "s") + " uploaded.";
    223 }
    handler.js
    
    
    
    
    jsProgress.js
    
      1 /*
      2     A simple class for displaying file information and progress
      3     Note: This is a demonstration only and not part of SWFUpload.
      4     Note: Some have had problems adapting this class in IE7. It may not be suitable for your application.
      5 */
      6 
      7 // Constructor
      8 // file is a SWFUpload file object
      9 // targetID is the HTML element id attribute that the FileProgress HTML structure will be added to.
     10 // Instantiating a new FileProgress object with an existing file will reuse/update the existing DOM elements
     11 function FileProgress(file, targetID) {
     12     this.fileProgressID = file.id;
     13 
     14     this.opacity = 100;
     15     this.height = 0;
     16     
     17 
     18     this.fileProgressWrapper = document.getElementById(this.fileProgressID);
     19     if (!this.fileProgressWrapper) {
     20         this.fileProgressWrapper = document.createElement("div");
     21         this.fileProgressWrapper.className = "progressWrapper";
     22         this.fileProgressWrapper.id = this.fileProgressID;
     23 
     24         this.fileProgressElement = document.createElement("div");
     25         this.fileProgressElement.className = "progressContainer";
     26 
     27         var progressCancel = document.createElement("a");
     28         progressCancel.className = "progressCancel";
     29         progressCancel.href = "#";
     30         progressCancel.style.visibility = "hidden";
     31         progressCancel.appendChild(document.createTextNode(" "));
     32 
     33         var progressText = document.createElement("div");
     34         progressText.className = "progressName";
     35         progressText.appendChild(document.createTextNode(file.name));
     36 
     37         var progressBar = document.createElement("div");
     38         progressBar.className = "progressBarInProgress";
     39 
     40         var progressStatus = document.createElement("div");
     41         progressStatus.className = "progressBarStatus";
     42         progressStatus.innerHTML = "&nbsp;";
     43 
     44         this.fileProgressElement.appendChild(progressCancel);
     45         this.fileProgressElement.appendChild(progressText);
     46         this.fileProgressElement.appendChild(progressStatus);
     47         this.fileProgressElement.appendChild(progressBar);
     48 
     49         this.fileProgressWrapper.appendChild(this.fileProgressElement);
     50 
     51         document.getElementById(targetID).appendChild(this.fileProgressWrapper);
     52     } else {
     53         this.fileProgressElement = this.fileProgressWrapper.firstChild;
     54         this.reset();
     55     }
     56 
     57     this.height = this.fileProgressWrapper.offsetHeight;
     58     this.setTimer(null);
     59 
     60 
     61 }
     62 
     63 FileProgress.prototype.setTimer = function (timer) {
     64     this.fileProgressElement["FP_TIMER"] = timer;
     65 };
     66 FileProgress.prototype.getTimer = function (timer) {
     67     return this.fileProgressElement["FP_TIMER"] || null;
     68 };
     69 
     70 FileProgress.prototype.reset = function () {
     71     this.fileProgressElement.className = "progressContainer";
     72 
     73     this.fileProgressElement.childNodes[2].innerHTML = "&nbsp;";
     74     this.fileProgressElement.childNodes[2].className = "progressBarStatus";
     75     
     76     this.fileProgressElement.childNodes[3].className = "progressBarInProgress";
     77     this.fileProgressElement.childNodes[3].style.width = "0%";
     78     
     79     this.appear();    
     80 };
     81 
     82 FileProgress.prototype.setProgress = function (percentage) {
     83     this.fileProgressElement.className = "progressContainer green";
     84     this.fileProgressElement.childNodes[3].className = "progressBarInProgress";
     85     this.fileProgressElement.childNodes[3].style.width = percentage + "%";
     86 
     87     this.appear();    
     88 };
     89 FileProgress.prototype.setComplete = function () {
     90     this.fileProgressElement.className = "progressContainer blue";
     91     this.fileProgressElement.childNodes[3].className = "progressBarComplete";
     92     this.fileProgressElement.childNodes[3].style.width = "";
     93 
     94     var oSelf = this;
     95     this.setTimer(setTimeout(function () {
     96         oSelf.disappear();
     97     }, 10000));
     98 };
     99 FileProgress.prototype.setError = function () {
    100     this.fileProgressElement.className = "progressContainer red";
    101     this.fileProgressElement.childNodes[3].className = "progressBarError";
    102     this.fileProgressElement.childNodes[3].style.width = "";
    103 
    104     var oSelf = this;
    105     this.setTimer(setTimeout(function () {
    106         oSelf.disappear();
    107     }, 5000));
    108 };
    109 FileProgress.prototype.setCancelled = function () {
    110     this.fileProgressElement.className = "progressContainer";
    111     this.fileProgressElement.childNodes[3].className = "progressBarError";
    112     this.fileProgressElement.childNodes[3].style.width = "";
    113 
    114     var oSelf = this;
    115     this.setTimer(setTimeout(function () {
    116         oSelf.disappear();
    117     }, 2000));
    118 };
    119 FileProgress.prototype.setStatus = function (status) {
    120     this.fileProgressElement.childNodes[2].innerHTML = status;
    121 };
    122 
    123 // Show/Hide the cancel button
    124 FileProgress.prototype.toggleCancel = function (show, swfUploadInstance) {
    125     this.fileProgressElement.childNodes[0].style.visibility = show ? "visible" : "hidden";
    126     if (swfUploadInstance) {
    127         var fileID = this.fileProgressID;
    128         this.fileProgressElement.childNodes[0].onclick = function () {
    129             swfUploadInstance.cancelUpload(fileID);
    130             return false;
    131         };
    132     }
    133 };
    134 
    135 FileProgress.prototype.appear = function () {
    136     if (this.getTimer() !== null) {
    137         clearTimeout(this.getTimer());
    138         this.setTimer(null);
    139     }
    140     
    141     if (this.fileProgressWrapper.filters) {
    142         try {
    143             this.fileProgressWrapper.filters.item("DXImageTransform.Microsoft.Alpha").opacity = 100;
    144         } catch (e) {
    145             // If it is not set initially, the browser will throw an error.  This will set it if it is not set yet.
    146             this.fileProgressWrapper.style.filter = "progid:DXImageTransform.Microsoft.Alpha(opacity=100)";
    147         }
    148     } else {
    149         this.fileProgressWrapper.style.opacity = 1;
    150     }
    151         
    152     this.fileProgressWrapper.style.height = "";
    153     
    154     this.height = this.fileProgressWrapper.offsetHeight;
    155     this.opacity = 100;
    156     this.fileProgressWrapper.style.display = "";
    157     
    158 };
    159 
    160 // Fades out and clips away the FileProgress box.
    161 FileProgress.prototype.disappear = function () {
    162 
    163     var reduceOpacityBy = 15;
    164     var reduceHeightBy = 4;
    165     var rate = 30;    // 15 fps
    166 
    167     if (this.opacity > 0) {
    168         this.opacity -= reduceOpacityBy;
    169         if (this.opacity < 0) {
    170             this.opacity = 0;
    171         }
    172 
    173         if (this.fileProgressWrapper.filters) {
    174             try {
    175                 this.fileProgressWrapper.filters.item("DXImageTransform.Microsoft.Alpha").opacity = this.opacity;
    176             } catch (e) {
    177                 // If it is not set initially, the browser will throw an error.  This will set it if it is not set yet.
    178                 this.fileProgressWrapper.style.filter = "progid:DXImageTransform.Microsoft.Alpha(opacity=" + this.opacity + ")";
    179             }
    180         } else {
    181             this.fileProgressWrapper.style.opacity = this.opacity / 100;
    182         }
    183     }
    184 
    185     if (this.height > 0) {
    186         this.height -= reduceHeightBy;
    187         if (this.height < 0) {
    188             this.height = 0;
    189         }
    190 
    191         this.fileProgressWrapper.style.height = this.height + "px";
    192     }
    193 
    194     if (this.height > 0 || this.opacity > 0) {
    195         var oSelf = this;
    196         this.setTimer(setTimeout(function () {
    197             oSelf.disappear();
    198         }, rate));
    199     } else {
    200         this.fileProgressWrapper.style.display = "none";
    201         this.setTimer(null);
    202     }
    203 };
    jsProgress.js
    
    
    

    defalut.css
      1 /* -----------------------------------------------
      2     www.swfupload.org
      3     Description: Common Screen Stylesheet for SWFUpload Demos
      4     Updated on:  May 1, 2008
      5 ----------------------------------------------- */
      6 
      7 
      8 /* ----------------------------------------------- 
      9     GLOBAL RESET 
     10    ----------------------------------------------- */
     11 
     12 html, body, div, span, applet, object, iframe,
     13 h1, h2, h3, h4, h5, h6, p, blockquote, pre,
     14 a, abbr, acronym, address, big, cite, code,
     15 del, dfn, font, img, ins, kbd, q, s, samp,
     16 small, strike, strong, sub, sup, tt, var,
     17 dl, dt, dd, ol, ul, li,
     18 fieldset, form, label, legend,
     19 table, caption, tbody, tfoot, thead, tr, th, td {
     20     margin: 0;
     21     padding: 0;
     22     border: 0;
     23     outline: 0;
     24     font-weight: inherit;
     25     font-style: inherit;
     26     font-size: 100%;
     27     font-family: inherit;
     28     vertical-align: baseline;
     29 }
     30 
     31 /* remember to define focus styles! */
     32 :focus { outline: 0; }
     33 body {
     34     line-height: 1;
     35     color: black;
     36     background: white;
     37 }
     38 ol, ul { 
     39     list-style: none; 
     40 }
     41 /* tables still need 'cellspacing="0"' in the markup */
     42 table {
     43     border-collapse: separate;
     44     border-spacing: 0;
     45 }
     46 caption, th, td {
     47     text-align: left;
     48     font-weight: normal;
     49 }
     50 blockquote:before, blockquote:after,
     51 q:before, q:after { 
     52     content: "";
     53 }
     54 blockquote, q {
     55     quotes: "" "";
     56 }
     57 
     58 
     59 /* ----------------------------------------------- 
     60     BASIC ELEMENTS
     61    ----------------------------------------------- */
     62    
     63    
     64 /* -- Text Styles ------------------------------- */
     65 html, 
     66 body {
     67     margin: 0;
     68     padding: 0;
     69      100%;
     70     font: 12px/1.4em Helvetica, Arial, sans-serif;
     71 }
     72 
     73 a { 
     74     color: #385ea2; 
     75     text-decoration: none; 
     76 }
     77 a:hover { text-decoration: underline; }
     78 
     79 strong { font-weight: 700; }
     80 
     81 h1 {
     82     font: 28px/1em  Arial, Helvetica, sans-serif;
     83     padding: 60px 20px 20px;
     84     margin-bottom: 15px;
     85     color: #333;
     86     text-decoration: none;
     87 }
     88 
     89 h1 a{
     90     color: #fff;
     91     text-decoration: none;
     92 }
     93 
     94 h2 { 
     95     font-size: 22px; 
     96     font-weight: 300;
     97     padding-top: 1em;
     98     padding-bottom: .25em;
     99 }
    100 
    101 
    102 p { 
    103     margin-top: .25em;
    104     margin-bottom: .5em;
    105 }
    106 
    107 ul { padding: 4px 5px; }
    108 ul li { 
    109     padding: 4px 5px; 
    110     margin: 0 20px;
    111     list-style:square; 
    112 }
    113 
    114 code {
    115     display: block;
    116     background:#edffb8 none repeat scroll 0%;
    117     border-color:#b2da3a;
    118     border-style:solid;
    119     border-1px 0;
    120     font-size: 1em;
    121     margin: 1em 0pt;
    122     overflow:auto;
    123     padding: 0.3em 0.4em;
    124     white-space:pre;
    125 }
    126 
    127 /* -- Layout ------------------------------- */
    128 
    129 
    130 #header {
    131     background: #313131 url(../images/header-bg.jpg) repeat-x top left;
    132     height: 125px;
    133     position: relative;
    134 }
    135     #logo { 
    136         padding: 0;
    137         margin: 0;
    138         background: url(../images/logo.gif) no-repeat 20px 20px;
    139         height: 106px;
    140          272px;
    141         text-indent: -5000px;
    142         overflow: hidden;
    143     }
    144     /* hide link text */
    145     #logo a {
    146         display: block;
    147         color: #fff;
    148         text-indent: -5000px;
    149         overflow: hidden;
    150         height: 106px;
    151          272px;
    152     }
    153     
    154     #version {
    155         color: #fff;
    156         position: absolute;
    157         right: 20px;
    158         top: 85px;
    159     }
    160 
    161 
    162 #content {  680px;}
    163 #content { margin: 20px 90px; }
    164 
    165 
    166 
    167 
    168 /* -- Form Styles ------------------------------- */
    169 form {    
    170     margin: 0;
    171     padding: 0;
    172 }
    173 
    174 
    175 
    176 div.fieldset {
    177     border:  1px solid #afe14c;
    178     margin: 10px 0;
    179     padding: 20px 10px;
    180 }
    181 div.fieldset span.legend {
    182     position: relative;
    183     background-color: #FFF;
    184     padding: 3px;
    185     top: -30px;
    186     font: 700 14px Arial, Helvetica, sans-serif;
    187     color: #73b304;
    188 }
    189 
    190 div.flash {
    191      375px;
    192     margin: 10px 5px;
    193     border-color: #D9E4FF;
    194 
    195     -moz-border-radius-topleft : 5px;
    196     -webkit-border-top-left-radius : 5px;
    197     -moz-border-radius-topright : 5px;
    198     -webkit-border-top-right-radius : 5px;
    199     -moz-border-radius-bottomleft : 5px;
    200     -webkit-border-bottom-left-radius : 5px;
    201     -moz-border-radius-bottomright : 5px;
    202     -webkit-border-bottom-right-radius : 5px;
    203 
    204 }
    205 
    206 button,
    207 input,
    208 select,
    209 textarea { 
    210     border- 1px; 
    211     margin-bottom: 10px;
    212     padding: 2px 3px;
    213 }
    214 
    215 
    216 
    217 input[disabled]{ border: 1px solid #ccc } /* FF 2 Fix */
    218 
    219 
    220 label { 
    221      150px; 
    222     text-align: right; 
    223     display:block;
    224     margin-right: 5px;
    225 }
    226 
    227 #btnSubmit { margin: 0 0 0 155px ; }
    228 
    229 /* -- Table Styles ------------------------------- */
    230 td {
    231     font: 10pt Helvetica, Arial, sans-serif;
    232     vertical-align: top;
    233 }
    234 
    235 .progressWrapper {
    236      357px;
    237     overflow: hidden;
    238 }
    239 
    240 .progressContainer {
    241     margin: 5px;
    242     padding: 4px;
    243     border: solid 1px #E8E8E8;
    244     background-color: #F7F7F7;
    245     overflow: hidden;
    246 }
    247 /* Message */
    248 .message {
    249     margin: 1em 0;
    250     padding: 10px 20px;
    251     border: solid 1px #FFDD99;
    252     background-color: #FFFFCC;
    253     overflow: hidden;
    254 }
    255 /* Error */
    256 .red {
    257     border: solid 1px #B50000;
    258     background-color: #FFEBEB;
    259 }
    260 
    261 /* Current */
    262 .green {
    263     border: solid 1px #DDF0DD;
    264     background-color: #EBFFEB;
    265 }
    266 
    267 /* Complete */
    268 .blue {
    269     border: solid 1px #CEE2F2;
    270     background-color: #F0F5FF;
    271 }
    272 
    273 .progressName {
    274     font-size: 8pt;
    275     font-weight: 700;
    276     color: #555;
    277      323px;
    278     height: 14px;
    279     text-align: left;
    280     white-space: nowrap;
    281     overflow: hidden;
    282 }
    283 
    284 .progressBarInProgress,
    285 .progressBarComplete,
    286 .progressBarError {
    287     font-size: 0;
    288      0%;
    289     height: 2px;
    290     background-color: blue;
    291     margin-top: 2px;
    292 }
    293 
    294 .progressBarComplete {
    295      100%;
    296     background-color: green;
    297     visibility: hidden;
    298 }
    299 
    300 .progressBarError {
    301      100%;
    302     background-color: red;
    303     visibility: hidden;
    304 }
    305 
    306 .progressBarStatus {
    307     margin-top: 2px;
    308      337px;
    309     font-size: 7pt;
    310     font-family: Arial;
    311     text-align: left;
    312     white-space: nowrap;
    313 }
    314 
    315 a.progressCancel {
    316     font-size: 0;
    317     display: block;
    318     height: 14px;
    319      14px;
    320     background-image: url(../images/cancelbutton.gif);
    321     background-repeat: no-repeat;
    322     background-position: -14px 0px;
    323     float: right;
    324 }
    325 
    326 a.progressCancel:hover {
    327     background-position: 0px 0px;
    328 }
    329 
    330 
    331 /* -- SWFUpload Object Styles ------------------------------- */
    332 .swfupload {
    333     vertical-align: top;
    334 }
    default.css
    
    
    
    
    
  • 相关阅读:
    Android | 教你如何开发一键银行卡绑定功能
    Android | 教你如何开发一个拍照翻译小程序
    Android | 教你如何开发一个证件照DIY小程序
    Android | 教你如何用三十分钟在安卓上开发一个微笑抓拍神器
    设计之禅——备忘录模式
    设计之禅——中介者模式
    设计之禅——解释器模式(译文)
    设计之禅——享元模式
    设计之禅——责任链模式
    设计之禅——桥接模式
  • 原文地址:https://www.cnblogs.com/zhangjun516/p/3259326.html
Copyright © 2011-2022 走看看