Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 91精品久久久久久久久久,最近最新中文字幕大全高清6,亚洲最大黄色

          整合營(yíng)銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          html基礎(chǔ)必備,前端小白一看就會(huì)

          么是HTML?

          首先,HTML是“超文本標(biāo)記語(yǔ)言”的縮寫(xiě)。這聽(tīng)起來(lái)可能有點(diǎn)嚇人,但這僅僅意味著它是一種用普通文本描述網(wǎng)頁(yè)的語(yǔ)言。HTML不是一種復(fù)雜的編程語(yǔ)言。

          HTML文件

          每個(gè)網(wǎng)頁(yè)實(shí)際上都是一個(gè)HTML文件。每個(gè)HTML文件只是一個(gè)純文本文件,但擴(kuò)展名為.HTML而不是.txt,由許多HTML標(biāo)記和網(wǎng)頁(yè)內(nèi)容組成。

          一個(gè)網(wǎng)站通常包含許多互相鏈接的html文件。你可以用任何你喜歡的編輯器來(lái)編輯HTML文件。

          HTML標(biāo)記

          HTML標(biāo)記是網(wǎng)頁(yè)中隱藏的關(guān)鍵字,用于定義web瀏覽器必須如何格式化和顯示內(nèi)容。

          大多數(shù)標(biāo)簽必須有兩個(gè)部分,一個(gè)開(kāi)始部分和一個(gè)結(jié)束部分。例如,<html>是開(kāi)始標(biāo)記,</html>是結(jié)束標(biāo)記。請(qǐng)注意,結(jié)束標(biāo)記與開(kāi)始標(biāo)記具有相同的文本,但有一個(gè)附加的正斜杠(/)字符,稱為“結(jié)束”或“關(guān)閉”字符。

          有些標(biāo)記是例外,并且不需要結(jié)束標(biāo)記,如用于顯示圖像的<img>標(biāo)記就是一個(gè)例子。

          每個(gè)HTML文件都必須存在一些有效的必要標(biāo)記,這樣web瀏覽器才能理解并正確顯示該文件。

          HTML文件的其余部分可以包含或多或少的標(biāo)記,用來(lái)展現(xiàn)內(nèi)容。

          標(biāo)記屬性

          屬性允許你自定義標(biāo)記的行為,在開(kāi)始標(biāo)記中定義,例如:

          <img src="image1.jpg">或<p align="center">...</p>

          屬性通常使用等號(hào)分配一個(gè)值,例如border="0"或width="50%",但是有些屬性只需要在標(biāo)記中聲明如下:<hr noshade>。

          大多數(shù)標(biāo)記的屬性都是可選的,僅當(dāng)您要更改瀏覽器顯示標(biāo)記的默認(rèn)方式時(shí)才使用。但是,有些標(biāo)記(如<img>標(biāo)記)具有src和alt等必需的屬性,這些屬性是瀏覽器正確顯示網(wǎng)頁(yè)所必需的。

          例子

          下面是一個(gè)基本的html文檔,包含所有必需的標(biāo)記。

          瀏覽器顯示內(nèi)容如下所示:

          有沒(méi)有想過(guò),為什么我們要有這么多技術(shù)來(lái)隱藏元素,而它們看起來(lái)都實(shí)現(xiàn)的是同樣的效果?每一種方法實(shí)際上與其他方法之間都有一些細(xì)微的不同,這些不同決定了在一個(gè)特定的場(chǎng)合下使用哪一個(gè)方法。今天就帶大家了解一下不同的方法分別用于那種場(chǎng)合更合適,下面就讓我們一起來(lái)看一看吧!

          一、opacity

          opacity 屬性的意思是設(shè)置一個(gè)元素的透明度。它不是為改變?cè)氐倪吔缈?bounding box)而設(shè)計(jì)的。這意味著將 opacity 設(shè)為 0 只能從視覺(jué)上隱藏元素。而元素本身依然占據(jù)它自己的位置并對(duì)網(wǎng)頁(yè)的布局起作用。它也將響應(yīng)用戶交互。

          .hide {
          opacity: 0;}
          

          如果你打算使用 opacity 屬性在讀屏軟件中隱藏元素,很不幸,你并不能如愿。元素和它所有的內(nèi)容會(huì)被讀屏軟件閱讀,就像網(wǎng)頁(yè)上的其他元素那樣。換句話說(shuō),元素的行為就和它們不透明時(shí)一致。

          我還要提醒一句,opacity 屬性可以用來(lái)實(shí)現(xiàn)一些效果很棒的動(dòng)畫(huà)。任何 opacity 屬性值小于 1 的元素也會(huì)創(chuàng)建一個(gè)新的堆疊上下文(stacking context)。

          看下面的例子:

          看 @SitePoint 提供的例子“用 opacity 隱藏元素”

          當(dāng)你的鼠標(biāo)移到被隱藏的第 2 個(gè)的區(qū)塊上,元素狀態(tài)平滑地從完全透明過(guò)渡到完全不透明。區(qū)塊也將 cursor 屬性設(shè)置為了 pointer,這說(shuō)明了用戶可以與它交互。

          二、visibility

          第二個(gè)要說(shuō)的屬性是 visibility。將它的值設(shè)為 hidden 將隱藏我們的元素。如同 opacity 屬性,被隱藏的元素依然會(huì)對(duì)我們的網(wǎng)頁(yè)布局起作用。與 opacity 唯一不同的是它不會(huì)響應(yīng)任何用戶交互。此外,元素在讀屏軟件中也會(huì)被隱藏。

          這個(gè)屬性也能夠?qū)崿F(xiàn)動(dòng)畫(huà)效果,只要它的初始和結(jié)束狀態(tài)不一樣。這確保了 visibility 狀態(tài)切換之間的過(guò)渡動(dòng)畫(huà)可以是時(shí)間平滑的(事實(shí)上可以用這一點(diǎn)來(lái)用 hidden 實(shí)現(xiàn)元素的延遲顯示和隱藏——譯者注)。

          .hide {
          visibility: hidden;}
          

          下面的例子演示了 visibility 與 opacity 有怎樣的不同:

          看 @SitePoint 提供的例子“用 visibility 隱藏元素”

          注意,如果一個(gè)元素的 visibility 被設(shè)置為 hidden,同時(shí)想要顯示它的某個(gè)子孫元素,只要將那個(gè)元素的 visibility 顯式設(shè)置為 visible 即可(就如例子里面的 .o-hide p——譯者注)。嘗試只 hover 在隱藏元素上,不要 hover 在 p 標(biāo)簽里的數(shù)字上,你會(huì)發(fā)現(xiàn)你的鼠標(biāo)光標(biāo)沒(méi)有變成手指頭的樣子。此時(shí),你點(diǎn)擊鼠標(biāo),你的 click 事件也不會(huì)被觸發(fā)。

          而在 <div> 標(biāo)簽里面的 <p> 標(biāo)簽則依然可以捕獲所有的鼠標(biāo)事件。一旦你的鼠標(biāo)移動(dòng)到文字上,<div> 本身變得可見(jiàn)并且事件注冊(cè)也隨之生效。

          三、display

          display 屬性依照詞義真正隱藏元素。將 display 屬性設(shè)為 none 確保元素不可見(jiàn)并且連盒模型也不生成。使用這個(gè)屬性,被隱藏的元素不占據(jù)任何空間。不僅如此,一旦 display 設(shè)為 none 任何對(duì)該元素直接打用戶交互操作都不可能生效。此外,讀屏軟件也不會(huì)讀到元素的內(nèi)容。這種方式產(chǎn)生的效果就像元素完全不存在。

          任何這個(gè)元素的子孫元素也會(huì)被同時(shí)隱藏。為這個(gè)屬性添加過(guò)渡動(dòng)畫(huà)是無(wú)效的,它的任何不同狀態(tài)值之間的切換總是會(huì)立即生效。

          不過(guò)請(qǐng)注意,通過(guò) DOM 依然可以訪問(wèn)到這個(gè)元素。因此你可以通過(guò) DOM 來(lái)操作它,就像操作其他的元素。

          .hide {
          display: none;}
          

          看下面的例子:

          @SitePoint 提供的例子“用 display 隱藏元素”

          你將看到第二個(gè)塊元素內(nèi)有一個(gè) <p> 元素,它自己的 display 屬性被設(shè)置成 block,但是它依然不可見(jiàn)。這是 visibility:hidden 和 display:none 的另一個(gè)不同之處。在前一個(gè)例子里,將任何子孫元素 visibility 顯式設(shè)置成 visible 可以讓它變得可見(jiàn),但是 display 不吃這一套,不管自身的 display值是什么,只要祖先元素的 display 是 one,它們就都不可見(jiàn)。

          現(xiàn)在,將鼠標(biāo)移到第一個(gè)塊元素上面幾次,然后點(diǎn)擊它。這個(gè)操作將讓第二個(gè)塊元素顯現(xiàn)出來(lái),它其中的數(shù)字將是一個(gè)大于 0 的數(shù)。這是因?yàn)?,元素即使被這樣設(shè)置成對(duì)用戶隱藏,還是可以通過(guò) JavaScript 來(lái)進(jìn)行操作。

          四、position

          假設(shè)有一個(gè)元素你想要與它交互,但是你又不想讓它影響你的網(wǎng)頁(yè)布局,沒(méi)有合適的屬性可以處理這種情況(opacity 和 visibility 影響布局, display 不影響布局但又無(wú)法直接交互——譯者注)。在這種情況下,你只能考慮將元素移出可視區(qū)域。這個(gè)辦法既不會(huì)影響布局,有能讓元素保持可以操作。下面是采用這 種辦法的 CSS:

          .hide {
          position: absolute;
          top: -9999px;
          left: -9999px;}
          

          下面的例子闡明了怎樣通過(guò)絕對(duì)定位的方式隱藏元素,并讓它和前面的那個(gè)例子效果一樣:

          看 @SitePoint 提供的例子“用 position 屬性隱藏元素”

          這種方法的主要原理是通過(guò)將元素的 top 和 left 設(shè)置成足夠大的負(fù)數(shù),使它在屏幕上不可見(jiàn)。采用這個(gè)技術(shù)的一個(gè)好處(或者潛在的缺點(diǎn))是用它隱藏的元素的內(nèi)容可以被讀屏軟件讀取。這完全可以理解,是因?yàn)槟阒皇菍⒃匾频娇梢晠^(qū)域外面讓用戶無(wú)法看到它。

          你得避免使用這個(gè)方法去隱藏任何可以獲得焦點(diǎn)的元素,因?yàn)槿绻敲醋觯?dāng)用戶讓那個(gè)元素獲得焦點(diǎn)時(shí),會(huì)導(dǎo)致一個(gè)不可預(yù)料的焦點(diǎn)切換。這個(gè)方法在創(chuàng)建 自定義復(fù)選框和單選按鈕時(shí)經(jīng)常被使用。(用 DOM 模擬復(fù)選框和單選按鈕,但用這個(gè)方法隱藏真正的 checkbox 和 radio 元素來(lái)“接收”焦點(diǎn)切換——譯者注)

          五、clip-path

          隱藏元素的另一種方法是通過(guò)剪裁它們來(lái)實(shí)現(xiàn)。在以前,這可以通過(guò) clip 屬性來(lái)實(shí)現(xiàn),但是這個(gè)屬性被廢棄了,換成一個(gè)更好的屬性叫做 clip-path。Nitish Kumar 最近在 SitePoint 發(fā)表了“介紹 clicp-path 屬性”這篇文章,通過(guò)閱讀它可以了解這個(gè)屬性的更多高級(jí)用法。

          記住,clip-path 屬性還沒(méi)有在 IE 或者 Edge 下被完全支持。如果要在你的 clip-path 中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用 clip-path 屬性來(lái)隱藏元素的代碼看起來(lái)如下:

          .hide {
          clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);}
          

          下面是一個(gè)實(shí)際使用它的例子:

          看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”

          如果你把鼠標(biāo)懸停在第一個(gè)元素上,它依然可以影響第二個(gè)元素,盡管第二個(gè)元素已經(jīng)通過(guò) clip-path 隱藏了。如果你點(diǎn)擊它,它會(huì)移除用來(lái)隱藏的 class,讓我們的元素從那個(gè)位置顯現(xiàn)出來(lái)。被隱藏元素中的文字仍然能夠通過(guò)讀屏軟件讀取,許多 WordPress 站點(diǎn)使用 clip-path 或者之前的 clip來(lái)實(shí)現(xiàn)專門(mén)為讀屏軟件提供的文字。

          雖然我們的元素自身不再顯示,它也依然占據(jù)本該占據(jù)的矩形大小,它周圍的元素的行為就如同它可見(jiàn)時(shí)一樣。記住用戶交互例如鼠標(biāo)懸?;蛘唿c(diǎn)擊在剪裁區(qū) 域之外也不可能生效。在我們的例子里,剪裁區(qū)大小為零,這意味著用戶將不能與隱藏的元素直接交互。此外,這個(gè)屬性能夠使用各種過(guò)渡動(dòng)畫(huà)來(lái)實(shí)現(xiàn)不同的效果。

          這五種CSS隱藏元素方法每一種用到的情況都不同,需要大家根據(jù)實(shí)際情況去判斷,隨著練習(xí)實(shí)戰(zhàn)的增多,相信大家對(duì)CSS隱藏元素就能做到得心應(yīng)手了。也可以加入465042726,一起討論關(guān)于web前端方面的問(wèn)題。



          在前面

          今年國(guó)慶假期終于可以憋在家里了不用出門(mén)了,不用出去看后腦了,真的是一種享受。這么好的光陰怎么浪費(fèi),睡覺(jué)、吃飯、打豆豆這怎么可能(耍多了也煩),完全不符合我們程序員的作風(fēng),趕緊起來(lái)把文章寫(xiě)完。

          這篇文章比較基礎(chǔ),在國(guó)慶期間的業(yè)余時(shí)間寫(xiě)的,這幾天又完善了下,力求把更多的前端所涉及到的關(guān)于文件上傳的各種場(chǎng)景和應(yīng)用都涵蓋了,若有疏漏和問(wèn)題還請(qǐng)留言斧正和補(bǔ)充。

          自測(cè)讀不讀

          以下是本文所涉及到的知識(shí)點(diǎn),break or continue ?

          • 文件上傳原理
          • 最原始的文件上傳
          • 使用 koa2 作為服務(wù)端寫(xiě)一個(gè)文件上傳接口
          • 單文件上傳和上傳進(jìn)度
          • 多文件上傳和上傳進(jìn)度
          • 拖拽上傳
          • 剪貼板上傳
          • 大文件上傳之分片上傳
          • 大文件上傳之?dāng)帱c(diǎn)續(xù)傳
          • node 端文件上傳

          原理概述

          原理很簡(jiǎn)單,就是根據(jù) http 協(xié)議的規(guī)范和定義,完成請(qǐng)求消息體的封裝和消息體的解析,然后將二進(jìn)制內(nèi)容保存到文件。

          我們都知道如果要上傳一個(gè)文件,需要把 form 標(biāo)簽的enctype設(shè)置為multipart/form-data,同時(shí)method必須為post方法。

          那么multipart/form-data表示什么呢?

          multipart互聯(lián)網(wǎng)上的混合資源,就是資源由多種元素組成,form-data表示可以使用HTML Forms 和 POST 方法上傳文件,具體的定義可以參考RFC 7578。

          multipart/form-data 結(jié)構(gòu)

          看下 http 請(qǐng)求的消息體



          • 請(qǐng)求頭:

          Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryDCntfiXcSkPhS4PN 表示本次請(qǐng)求要上傳文件,其中boundary表示分隔符,如果要上傳多個(gè)表單項(xiàng),就要使用boundary分割,每個(gè)表單項(xiàng)由———XXX開(kāi)始,以———XXX結(jié)尾。

          • 消息體- Form Data 部分

          每一個(gè)表單項(xiàng)又由Content-Type和Content-Disposition組成。

          Content-Disposition: form-data 為固定值,表示一個(gè)表單元素,name 表示表單元素的 名稱,回車換行后面就是name的值,如果是上傳文件就是文件的二進(jìn)制內(nèi)容。

          Content-Type:表示當(dāng)前的內(nèi)容的 MIME 類型,是圖片還是文本還是二進(jìn)制數(shù)據(jù)。

          解析

          客戶端發(fā)送請(qǐng)求到服務(wù)器后,服務(wù)器會(huì)收到請(qǐng)求的消息體,然后對(duì)消息體進(jìn)行解析,解析出哪是普通表單哪些是附件。

          可能大家馬上能想到通過(guò)正則或者字符串處理分割出內(nèi)容,不過(guò)這樣是行不通的,二進(jìn)制buffer轉(zhuǎn)化為string,對(duì)字符串進(jìn)行截取后,其索引和字符串是不一致的,所以結(jié)果就不會(huì)正確,除非上傳的就是字符串。

          不過(guò)一般情況下不需要自行解析,目前已經(jīng)有很成熟的三方庫(kù)可以使用。

          至于如何解析,這個(gè)也會(huì)占用很大篇幅,后面的文章在詳細(xì)說(shuō)。

          最原始的文件上傳

          使用 form 表單上傳文件

          在 ie時(shí)代,如果實(shí)現(xiàn)一個(gè)無(wú)刷新的文件上傳那可是費(fèi)老勁了,大部分都是用 iframe 來(lái)實(shí)現(xiàn)局部刷新或者使用 flash 插件來(lái)搞定,在那個(gè)時(shí)代 ie 就是最好用的瀏覽器(別無(wú)選擇)。

          DEMO



          這種方式上傳文件,不需要 js ,而且沒(méi)有兼容問(wèn)題,所有瀏覽器都支持,就是體驗(yàn)很差,導(dǎo)致頁(yè)面刷新,頁(yè)面其他數(shù)據(jù)丟失。

          HTML

           <form method="post" action="http://localhost:8100" enctype="multipart/form-data">
          
                  選擇文件:
                      <input type="file" name="f1"/> input 必須設(shè)置 name 屬性,否則數(shù)據(jù)無(wú)法發(fā)送<br/>
          <br/>
                      標(biāo)題:<input type="text" name="title"/><br/><br/><br/>
          
                  <button type="submit" id="btn-0">上 傳</button>
          
          </form>
          
          復(fù)制代碼

          文件上傳接口

          服務(wù)端文件的保存基于現(xiàn)有的庫(kù)koa-body結(jié)合 koa2實(shí)現(xiàn)服務(wù)端文件的保存和數(shù)據(jù)的返回。

          在項(xiàng)目開(kāi)發(fā)中,文件上傳本身和業(yè)務(wù)無(wú)關(guān),代碼基本上都可通用。

          在這里我們使用koa-body庫(kù)來(lái)實(shí)現(xiàn)解析和文件的保存。

          koa-body 會(huì)自動(dòng)保存文件到系統(tǒng)臨時(shí)目錄下,也可以指定保存的文件路徑。



          然后在后續(xù)中間件內(nèi)得到已保存的文件的信息,再做二次處理。

          • ctx.request.files.f1 得到文件信息,f1為input file 標(biāo)簽的 name
          • 獲得文件的擴(kuò)展名,重命名文件

          NODE

          /**
           * 服務(wù)入口
           */
          var http = require('http');
          var koaStatic = require('koa-static');
          var path = require('path');
          var koaBody = require('koa-body');//文件保存庫(kù)
          var fs = require('fs');
          var Koa = require('koa2');
          
          var app = new Koa();
          var port = process.env.PORT || '8100';
          
          var uploadHost= `http://localhost:${port}/uploads/`;
          
          app.use(koaBody({
              formidable: {
                  //設(shè)置文件的默認(rèn)保存目錄,不設(shè)置則保存在系統(tǒng)臨時(shí)目錄下  os
                  uploadDir: path.resolve(__dirname, '../static/uploads')
              },
              multipart: true // 開(kāi)啟文件上傳,默認(rèn)是關(guān)閉
          }));
          
          //開(kāi)啟靜態(tài)文件訪問(wèn)
          app.use(koaStatic(
              path.resolve(__dirname, '../static') 
          ));
          
          //文件二次處理,修改名稱
          app.use((ctx) => {
              var file = ctx.request.files.f1;//得道文件對(duì)象
              var path = file.path;
              var fname = file.name;//原文件名稱
              var nextPath = path+fname;
              if(file.size>0 && path){
                  //得到擴(kuò)展名
                  var extArr = fname.split('.');
                  var ext = extArr[extArr.length-1];
                  var nextPath = path+'.'+ext;
                  //重命名文件
                  fs.renameSync(path, nextPath);
              }
              //以 json 形式輸出上傳文件地址
              ctx.body = `{
                  "fileUrl":"${uploadHost}${nextPath.slice(nextPath.lastIndexOf('/')+1)}"
              }`;
          });
          
          /**
           * http server
           */
          var server = http.createServer(app.callback());
          server.listen(port);
          console.log('demo1 server start ......   ');
          復(fù)制代碼

          CODE

          https://github.com/Bigerfe/fe-learn-code/


          主站蜘蛛池模板: 无码人妻一区二区三区免费看| 免费人人潮人人爽一区二区| 国产成人精品亚洲一区| 激情内射亚洲一区二区三区爱妻| 制服美女视频一区| 精品乱子伦一区二区三区高清免费播放| 无码人妻一区二区三区免费n鬼沢| 国产综合精品一区二区| 国产福利酱国产一区二区| 免费观看一区二区三区| 国产免费伦精品一区二区三区| 婷婷亚洲综合一区二区| 少妇精品久久久一区二区三区| 国产精品免费一区二区三区| 区三区激情福利综合中文字幕在线一区| 免费一区二区无码视频在线播放| 亚洲色无码一区二区三区| 中文字幕一区二区三匹| 无码国产精品一区二区免费虚拟VR| 91精品福利一区二区| 精品性影院一区二区三区内射 | 波多野结衣一区二区免费视频| 3D动漫精品一区二区三区| 日韩国产免费一区二区三区| 亚洲视频免费一区| 亚洲高清毛片一区二区| 亚洲综合av一区二区三区不卡| 亚洲日韩中文字幕一区| 精品久久久中文字幕一区| 国产肥熟女视频一区二区三区| 美女视频免费看一区二区| 乱人伦一区二区三区| 久久久久人妻精品一区三寸蜜桃| 色噜噜AV亚洲色一区二区| 日韩亚洲一区二区三区| 亚洲一本一道一区二区三区| 国产在线观看一区二区三区| 亚洲福利视频一区| 肉色超薄丝袜脚交一区二区| 久久国产精品免费一区二区三区| 亚洲乱码日产一区三区 |