摘要:換一臺電腦就要重新安裝。并且還需要適配不同的系統(tǒng)。提交大小幾乎沒有限制。即協(xié)議主要由請求和響應(yīng)組成。相反則為同步按照程序的順序,依次往下執(zhí)行,必須等上一程序執(zhí)行完成之后才能執(zhí)行下一程序,阻礙程序的執(zhí)行。
Ajax 服務(wù)器 類型
按照服務(wù)類型:文件服務(wù)器,數(shù)據(jù)庫服務(wù)器,郵件服務(wù)器,Web服務(wù)器
按照操作系統(tǒng):Linux服務(wù)器,Windows服務(wù)器
按照應(yīng)用軟件:Apache服務(wù)器,Nginx服務(wù)器,IIS服務(wù)器,Tomcat服務(wù)器,WebSphere服務(wù)器,boss服務(wù)器,Node服務(wù)器
軟件文件服務(wù)器:Server-U,F(xiàn)ileZilla,VsFTP(File Transfer Protocol)等
數(shù)據(jù)庫服務(wù)器:oracle,mysql,SQL server,DB2,ACCESS等
郵件服務(wù)器:Postfix,Sendmail等
HTTP服務(wù)器:Apache,Nginx,IIS,Tomcat,NodeJS等
HTTP服務(wù)器網(wǎng)站服務(wù)器,主要提供文檔(文本,圖片,視頻,音頻)瀏覽服務(wù)
可以結(jié)合某一種編程語言處理業(yè)務(wù)邏輯,由此進行開發(fā),被稱為服務(wù)端開發(fā)
常見的編程語言有php,java,.net,Python,Ruby,Perl等
客戶端向服務(wù)端索取服務(wù)能力的終端
以瀏覽器為環(huán)境,結(jié)合HTML,CSS,JavaScript進行的開發(fā)叫做前端開發(fā)
網(wǎng)絡(luò) IP地址32位(二進制),查看本機IP地址:ping,ipconfig,ifconfig(Linux)
域名IP基于數(shù)字,不方便記憶,用域名代替IP地址
DNS服務(wù)Domain Name System:域名和IP地址相互映射的一個分布式數(shù)據(jù)庫
記錄IP地址和域名之間對應(yīng)關(guān)系的服務(wù)
優(yōu)先級:本機的host優(yōu)先于DNS服務(wù)器
ipconfig、flushdns刷新DNS
客戶端將域名傳入DNS,DNS把域名轉(zhuǎn)換成IP地址返回給客戶端,之后客戶端根據(jù)IP地址發(fā)送請求給服務(wù)器,服務(wù)器響應(yīng),返回信息
端口端口是計算機與外界通訊交流的出口,每個端口對應(yīng)不同的服務(wù)
查看端口占用情況:netstat-an
常見端口:80,8080,3306,21,22
架構(gòu) C/S結(jié)構(gòu)Client Sever不同的服務(wù)器需要安裝不同的客戶端軟件
比如 QQ,迅雷等一系列軟件。換一臺電腦就要重新安裝。并且還需要適配不同的系統(tǒng)。不方便
B/S結(jié)構(gòu)Broswer Sever所有的服務(wù)都可以通過瀏覽器來完成,不需要兼容操作系統(tǒng),不同客戶端都可以操作
比如百度腦圖
操作穩(wěn)定性較差,流暢度較弱
PHP 簡單程序地址欄模擬
默認返回的內(nèi)容,瀏覽器解析成html
每句代碼必須加分號
PHP:Hypertext Preprocessor超文本預(yù)處理器
PHP語言的運算符和JS一樣
變量變量以$開頭,由字母數(shù)字下劃線組成,不能以數(shù)字開頭
大小寫敏感(區(qū)分大小寫)
輸出順序是自上向下的,相當(dāng)于js中的document.write()
單引號中的內(nèi)容就是字符串
雙引號中的內(nèi)容會執(zhí)行
符后面的內(nèi)容和構(gòu)成一個變量名稱
如果前邊聲明的變量是$name=xgg;
輸出echo “$name17” 會報錯,因為找不到名為”name17”的變量
輸出echo “$name 17” 會輸出 xgg 17
數(shù)據(jù)類型
要注意索引數(shù)組和關(guān)聯(lián)數(shù)組的區(qū)別
"itcast","age"=>10); echo $arr["name"]; echo $arr["age"]; ?>
public相當(dāng)于JS中的全局變量
private相當(dāng)于JS中的局部變量
對象
name; ?>
null是PHP中一種特殊的數(shù)據(jù)類型,表示空值,表示為該變量設(shè)置任何值null,不區(qū)分大小寫,null和NULL一樣
運算符&內(nèi)容輸出echo:輸出簡單數(shù)據(jù)類型,如字符串,數(shù)值。如果用echo輸出數(shù)組,只能得到類型名字,得不到內(nèi)容
print_r():輸出復(fù)雜數(shù)據(jù)類型的結(jié)構(gòu),如數(shù)組
var_dump():輸出詳細信息,如對象,數(shù)組
$arr=array("itcast","今年","10歲了"); //只能輸出簡單類型 echo $arr; //輸出詳細信息 print_r($arr); $hello="hello"; //輸出詳細信息 var_dump($hello);函數(shù)
PHP中有超過700個內(nèi)建函數(shù)
函數(shù)名對大小寫不敏感
有參數(shù)一定傳,但是如果有默認值可以不傳
表單表單name屬性設(shè)置服務(wù)端接收所傳遞數(shù)據(jù),如果不帶name屬性就無法提交
表單action屬性設(shè)置接收數(shù)據(jù)的處理程序,表示提交的地址(后臺處理程序)
表單method屬性設(shè)置發(fā)送數(shù)據(jù)的方式,表示提交的方式
當(dāng)上傳文件時需要設(shè)置enctype=”multipart/form-data”,并且只能用post的方式上傳
遞交方式和獲取方式要對應(yīng)
$_GET,PHP的內(nèi)置變量,接收get傳值(簡單數(shù)據(jù)類型)默認提交方式(提交數(shù)據(jù)拼接到URL地址欄中)提交大小4k左右(地址欄長度有限)
$_POST,PHP的內(nèi)置變量,接收post傳值(簡單數(shù)據(jù)類型)數(shù)據(jù)提交到請求報文中(更安全)。提交大小幾乎沒有限制。
$_FILES,PHP的內(nèi)置變量,接收文件上傳(獲取文件類型)
$\_POST,$_GET獲取的都是字符串類型的數(shù)據(jù)
$_FILES獲取文件類型數(shù)據(jù)
文件導(dǎo)入include導(dǎo)入的是HTML頁面
require導(dǎo)入的是PHP程序
傳輸協(xié)議 HTTPHTTP(HyperText Transfer Protocol)超文本傳輸協(xié)議
HTML(HyperText Markup Language)超文本標(biāo)記語言
http協(xié)議是由客戶端到服務(wù)器的請求(request)和從服務(wù)器到客戶端的響應(yīng)(response)進行了約束和規(guī)范。即http協(xié)議主要由請求和響應(yīng)組成。
常用的請求方法POST,GET,PUT,DELETE
GET和POST請求方式的差異
GET沒有請求主體,使用xhl.send(null)
GET可以通過在請求URL上添加請求參數(shù)
POST可以通過設(shè)置xhl.send(‘name=itcast&age=17’)
POST需要設(shè)置
GET效率更好
GET大小限制4k,POST沒有限制
請求和請求報文由客戶端發(fā)起,規(guī)范為:請求行,請求頭,請求主體
請求行:
get方式會在地址后面拼接參數(shù)
/heima11/day02/03.form.php?username=xgg&password=1 HTTP/1.1
post方式就是簡單的地址
/heima11/day02/03.form.php HTTP/1.1
請求頭:
Host:localhost請求的主機
User-Agent:很重要,包含客戶端的信息
Accept:接受的文檔MIME類型,text/html,application/xhtml+xml等內(nèi)容
Accept-Language:可接受的語言,zh-CN等內(nèi)容
Accept-Encoding:可接受的壓縮格式,gzip,deflate,sdch,br等內(nèi)容
Cache-Control:max-age=0控制緩存
Content-Type:application/x-www-form-urlencoded以post形式提交表單的時候,請求頭中會設(shè)置這一項,以get形式提交,則沒有
Referer:從哪個URL跳轉(zhuǎn)過來的
請求主體:
post方式,傳遞給服務(wù)端的數(shù)據(jù)
get方式,空的
響應(yīng)和響應(yīng)報文由服務(wù)器發(fā)起,規(guī)范為:狀態(tài)行,響應(yīng)頭,響應(yīng)主體
狀態(tài)行:
由協(xié)議版本號,狀態(tài)碼和狀態(tài)信息構(gòu)成
200成功,304緩存,403權(quán)限,404未找到,500+服務(wù)端錯誤
響應(yīng)頭:
Date:響應(yīng)時間
Server:服務(wù)器信息
Content-Length:響應(yīng)主體長度
Content-Type:響應(yīng)資源的類型
響應(yīng)主體:
服務(wù)端返給客戶端的內(nèi)容
Ajax編程 異步程序執(zhí)行時不會阻塞其他程序執(zhí)行,程序的執(zhí)行順序不依賴程序本身的書寫順序。相反則為同步(按照程序的順序,依次往下執(zhí)行,必須等上一程序執(zhí)行完成之后才能執(zhí)行下一程序,阻礙程序的執(zhí)行)。
XMLHttpRequest瀏覽器內(nèi)建對象,用于在后臺與服務(wù)器通信(交換數(shù)據(jù)),可以實現(xiàn)對網(wǎng)頁的部分更新,而不是刷新整個頁面
請求請求行數(shù)據(jù)直接加到地址欄后面
請求頭內(nèi)容默認
請求主體為空
通過encodeURI()用來對中文參數(shù)進行轉(zhuǎn)碼,防止亂碼
請求行就是地址
請求頭需要Content-Type的設(shè)置
請求主體發(fā)送請求
響應(yīng)readyState有五種狀態(tài)
0 請求未初始化
1 請求已經(jīng)建立,但是還沒有發(fā)送
2 請求已經(jīng)發(fā)送,正在處理中
3 請求在處理中,響應(yīng)有部分數(shù)據(jù)可用
4 響應(yīng)已完成
服務(wù)器作出響應(yīng)需要時間,所以需要監(jiān)聽服務(wù)器的狀態(tài)
當(dāng)readyState的狀態(tài)發(fā)生改變的時候,觸發(fā)onreadystatechange函數(shù)
XML指的是可擴展標(biāo)記語言,主要用來輸出和存儲數(shù)據(jù)
必須有一個根元素,可以自定義,標(biāo)簽也可以自定義
空格會被保留,所以不可有空格,不可以數(shù)字或點開頭,大小寫敏感
不可交叉嵌套
可以在標(biāo)簽里定義屬性,屬性雙引號單引號都可以(瀏覽器自動修正成雙引號)
特殊符號用實體 & gt;& lt;& nbsp;
注釋寫法和HTML一樣,不能放在開頭
必須閉合(雙標(biāo)簽)
xml本質(zhì)是字符串,瀏覽器在解析的時候,會按照xml格式去預(yù)覽
可以描述和傳輸復(fù)雜的數(shù)據(jù),但是解析獲取復(fù)雜并且體積大,開發(fā)很少使用
在忽略互聯(lián)網(wǎng)速度的內(nèi)網(wǎng)還是可以用XML
銀行網(wǎng)銀系統(tǒng)中大量使用
XML是用來傳輸和存儲數(shù)據(jù)的,而HTML被設(shè)計用來顯示數(shù)據(jù)的
XML旨在傳輸數(shù)據(jù),HTML旨在顯示信息
php中用file_get_contents的方式獲取xml元素
header中一定要把html改成xml否則會報錯
通過responseText獲取的內(nèi)容是字符串
通過responseXML獲取的內(nèi)容
JSON輕量級文本數(shù)據(jù)交換格式
獨立于語言(每種語言都認識)
數(shù)據(jù)在名稱/值對中
不能寫注釋
數(shù)據(jù)由逗號分隔(最后一個鍵值對不能帶逗號)
花括號里面只有一條數(shù)據(jù)的時候,不加逗號(相當(dāng)于最后一條數(shù)據(jù))
花括號保存對象方括號保存數(shù)組
使用雙引號
json對象沒有變量
json形式的數(shù)據(jù)結(jié)尾沒有分號
json數(shù)據(jù)中的鍵必須用雙引號包括
比XML更小更快更容易解析
在數(shù)據(jù)的傳輸過程中,json以文本方式傳輸,JS操作的是json對象,所以json對象和json字符串之間需要相互轉(zhuǎn)換
JSON.parse json轉(zhuǎn)換成javascript
JSON.stringify javascript轉(zhuǎn)換成json
json_decode json轉(zhuǎn)換成php
json_encode php轉(zhuǎn)換成json
模板引擎 artTemplate 語法概述模板:參照html代碼和數(shù)據(jù)綁定
script type=”text/html”不讓內(nèi)容當(dāng)做js解析執(zhí)行,在頁面中不存在
模板綁定后可以在模板內(nèi)書寫模板語法
模板語法只能書寫在<% %>中
使用數(shù)據(jù)的時候,如果這個數(shù)據(jù)是傳入對象的屬性,這個屬性相當(dāng)于一個模板內(nèi)可以使用的變量
模板的特殊語法和js一樣,模板內(nèi)部可以定義變量,使用分支循環(huán)語句
不能使用模板外部變量(全局變量),例如$,window,console等
默認渲染方式是字符串:<%= %>默認渲染方式是字符串,防止xss攻擊(cross site scripting 跨站腳本攻擊) <%=# %>默認渲染方式是html,從后臺傳過來的數(shù)據(jù)可以是 html標(biāo)簽
簡潔模板必須寫在{{}}中
{{each model}} {{/each}}默認索引$index 默認值$value
{{each model as item i}} {{/each}}默認索引item值 i索引
{{if}}{{else}}{{/if}}分支
簡介模板不能定義變量
模板引擎作用,渲染工具(把數(shù)據(jù)動態(tài)生成html格式的代碼渲染在頁面當(dāng)中)
國外:handlebars,mustache
國內(nèi):artTemplate最好,baiduTemplate,velocity
使用步驟:準(zhǔn)備數(shù)據(jù),準(zhǔn)備模板,數(shù)據(jù)和模板綁定返回html格式的字符串,渲染頁面
瀑布流加載方法window.onload和$(function)的區(qū)別
window.onload是將文檔中所有的元素都加載出來
$(function() {})是將文檔中主要元素加載出來
圖片還沒有加載出來的時候,下面如果排新的子容器,就會把上面的圖片蓋住,出現(xiàn)圖片黏連的情況
兩種解決方案:
需要用window.onload,先把圖片都加載出來,防止這種情況發(fā)生
限定圖片的尺寸,圖片沒有加載出來的時候,尺寸也可以先占空間,尺寸可以由后臺數(shù)據(jù)傳到前端,根據(jù)子容器的比例,算出圖片的大小再進行設(shè)置
一部分瀏覽器有兼容問題,在動態(tài)渲染20個容器的時候,選擇器可能會失效
跨域 跨域&同源同源:協(xié)議域名端口號一樣
瀏覽器一般會阻止跨域的操作(同源策略)
具有跨域能力的標(biāo)簽,不具有操作跨域元素的能力
link可以請求跨域的數(shù)據(jù),不能取到內(nèi)容
script通過src的請求,都是get請求,后臺返回的內(nèi)容引入進來,不管返回的是什么類型,都會被解析成JS并執(zhí)行,但是可能會報錯(不符合JS語法)
iframe能對同源文檔中的元素進行操作,實際是在頁面中開了一個內(nèi)嵌的頁面
domain手動設(shè)置頂級域名,跨域可以互相操作,但是兩個域的頂級域名必須相同,并且兩個域需要同時設(shè)置document.domain=’頂級域名’
其他hash、name、postMessage
JSONPxhr無法進行跨域請求
JSONP原理:動態(tài)創(chuàng)建script標(biāo)簽,通過src屬性發(fā)送跨域請求,服務(wù)端返回一個預(yù)先定義好的javascript函數(shù)的調(diào)用
發(fā)送之前必須顯示先聲明一個函數(shù),函數(shù)名字與參與傳遞的名字要一致
核心是動態(tài)添加script標(biāo)簽來調(diào)用服務(wù)器提供的
遵循js語法,定義一個變量,根據(jù)變量獲取后臺數(shù)據(jù)
前端定義一個函數(shù)success,后臺返回一個函數(shù) callback=success,理解成成功回調(diào)函數(shù)
可以傳復(fù)雜數(shù)據(jù),通過拼接JSON格式的數(shù)據(jù),返回的就是JSON對象
一端維護,callback值是前后端的約定,jQuery會自動生成callback
因為是get請求,所以只能在地址欄拼接數(shù)據(jù)
JSONP的jQuery語法,與JSON的jQuery的語法比較,強制類型轉(zhuǎn)換改成jsonp就可以了
cors如果傳輸?shù)臄?shù)據(jù)量比較大,那么需要用post的方式進行傳輸,就不能再使用JSONP,應(yīng)該使用cors
使用方法:添加屬性,允許某個域名訪問。弊端:存在瀏覽器兼容問題
*表示通配符,表示所有網(wǎng)站都可以訪問,不安全
可以加具體的域名,比如http://yueban.com
jQuery提供的方法$.ajax({ //以何種方式進行傳輸 type:"post", //地址 url:"../api/removeUser.php", //傳輸?shù)臄?shù)據(jù) data:{id:id}, //傳輸數(shù)據(jù)的類型,默認是json,有jsonp形式 dataType:"json", //發(fā)送數(shù)據(jù)之前的函數(shù) beforeSend:function(){ $btn.addClass("btn-loading") }, //成功之后的函數(shù),可以傳入數(shù)據(jù) success:function(data){ $btn.removeClass("btn-loading"); if(data.status=="ok"){ $deletModal.modal("hide"); render(); } } })
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/97374.html
摘要:需要注意的是,并不是的替代品,兩者各自有其適應(yīng)的場景。但為了方便交流,我們通常將獲取資源的一方稱為客戶端主要的工具是瀏覽器,而將派發(fā)資源的一方稱為服務(wù)端又稱為服務(wù)器。它可以幫助我們?yōu)橹蟾拍罴毠?jié)的學(xué)習(xí)打下良好基礎(chǔ)。 再也不學(xué)AJAX了是一個與AJAX主題相關(guān)的文章系列,包含以下三個部分的內(nèi)容: AJAX概述:主要回答AJAX是什么這個問題; 使用AJAX:介紹如何通過JavaSc...
摘要:即同步請求,瀏覽器需要等待服務(wù)器處理請求,導(dǎo)致了瀏覽器端的阻塞。這使得應(yīng)用程序更為迅捷地回應(yīng)用戶動作,并避免了在網(wǎng)絡(luò)上發(fā)送那些沒有改變的信息。引擎在客戶端運行,承擔(dān)了一部分本來由服務(wù)器承擔(dān)的工作,從而減少了大用戶量下的服務(wù)器負載。 前言 博主博客:Stillwater的博客知乎專欄:前端汪汪本文為作者原創(chuàng)轉(zhuǎn)載請注明出處: http://hiztx.top/2017/01/11/a......
摘要:回調(diào)函數(shù)指定了下一步操作。異步操作的流程控制參數(shù)為秒后返回結(jié)果上面代碼的函數(shù)是一個異步任務(wù),非常耗時,每次執(zhí)行需要秒才能完成,然后再調(diào)用回調(diào)函數(shù)。 單線程模型同步任務(wù)和異步任務(wù)任務(wù)隊列和事件循環(huán)異步操作的模式回調(diào)函數(shù)事件監(jiān)聽發(fā)布/訂閱異步操作的流程控制串行執(zhí)行并行執(zhí)行并行與串行的結(jié)合 1.單線程模型指的是js只在線程運行,一個時間執(zhí)行一個任務(wù),其他任務(wù)排隊。事實上是一個運行腳本的主線程...
閱讀 1187·2021-11-23 10:10
閱讀 1521·2021-09-30 09:47
閱讀 905·2021-09-27 14:02
閱讀 2979·2019-08-30 15:45
閱讀 3026·2019-08-30 14:11
閱讀 3620·2019-08-29 14:05
閱讀 1828·2019-08-29 13:51
閱讀 2211·2019-08-29 11:33