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
和這個問題有關概念的一個應用場景是:當你需要在不同操作系統平臺(例如Unix和Windows)之間切換時,尤其是由一平臺生成的文檔在另一平臺查看時,就必須搞清楚 回車”(Carriage Return, CR)和“換行”(Line Feed, LF)這兩個概念之間的區別。
電腦筆記本鍵盤上的回車鍵按鈕
為回答這個問題,從下面的實驗開始。
在Windows下創建一個txt文檔,輸入'123456'六個數字并“回車\enter”,
保存后,查看屬性,占8個字節,即輸入了八個字符,則剛才的“回車/enter”一定占了兩個字節!
這兩個字節是啥呢?
用UltraEdit軟件打開該文件,查看這是個符號的十六進制,可得:第一個符號的ASCII碼為31(十六進制),對于的符號為為數字'1';…;第七個符號的ASCII碼為 0D(十六進制),對應的符號為CR(回車);最后一個字符即第八個符號的ASCII碼為 0A(十六進制),對應的符號為LF (換行)。
結論:Windows下處理回車的效果是:回車換行,即兩個字符(\r\n ).
答案是:兩個字符\r\n.
在Windows系統下運行下面兩個程序:
程序一:
#include <stdio.h>
void main( )
{
FILE *fp;
if((fp=fopen("test.txt","w"))==NULL) {
printf("Open the test.txt file error\n");
}
for(int i=0;i<10;i++){
fprintf(fp,"test\n");
}
fclose(fp);
}
程序二:
#include <stdio.h>
void main( )
{
FILE *fp;
if((fp=fopen("test.bin","wb"))==NULL) {
printf("Open the test.bin file error\n");
}
for(int i=0;i<10;i++){
fprintf(fp,"test\n");
}
fclose(fp);
}
程序一輸出文件test.txt的大小是60字節,程序二輸出文件大小是50字節,用記事本打開程序一的輸出沒有什么問題,每行一個test. 打開程序二的輸出文件test.bin時發現所有的test連成一行,test之間是一個黑色方框符號分隔。用UltraEdit-32以16進制編輯模式打開test.bin可以查看到黑色方框符號就是0A也就是\n,打開test.txt則會發現換行是\r\n,這就是兩個文件大小相差10字節的原因。Unix類系統用戶打開windows中的文件就會遇到這種苦惱。
為什么會有這種區別呢?
由于Unix系統是基于C語言編寫的,C語言中使用\n表示換行,而在實際的文件中換行符號需要同操作系統一致,所以當我們在C中使用fopen打開一個文本文件時流實現了實際換行符與C中\n之間的轉換。在Windows中當用fopen打開文本文件,然后從中讀到\r\n時流會轉換為\n,而當我們往文件中寫入\n時流會轉換為\r\n。程序一是打開文本文件,程序二打開的是二進制文件,因為流只對文本文件進行換行表示的轉換,以二進制模式打開流不會做任何處理。所以當你以二進制模式打開一個文本文件時將產生錯亂,你必須親自將\r\n解釋為\n,同樣的問題也會出現在以文本模式打開二進制文件的情況.這也解釋了為什么Unix類系統中的文件不區分文本文件和二進制文件的原因。
硬回車:enter
作用:換行的同時分隔段落;
在word中敲擊Enter鍵產生的那個彎曲的小箭頭,占兩個字節。如下圖所示:
軟回車: Shift + Enter
作用:換行,但是并不換段,即前后兩段文字在 Word 中屬于同一“段”。在應用格式時能看出明顯區別,體會到這一點。
軟回車只占一個字節,在word中是一個向下的箭頭。符如下圖所示:
當我們需要將從網頁上找到資料復制粘貼到word文檔中時,經??吹杰浕剀嚪枺@是因為軟回車在網頁設計中具有舉足輕重的地位的:
軟回車能使前后兩行的行間距大幅度縮小,因為它不是段落標記,要和法定的段落標記——硬回車區別出來。硬回車的html代碼是<p>..</p>,段落的內容就夾在里面,而軟回車的代碼很精悍:<br>。因此在網頁中想用到軟回車,只需切換到代碼頁面,鍵入軟回車的代碼即可。
最后,本篇筆記開始的那個問題就很明確了:“Windows(CRLF)”是編輯器對Windows系統下,“回車”操作符等效為“\r\n”的一個提示。其實,在windows系統中的很多編輯環境中都有很多類似的提示,你能發現哪些呢?歡迎在評論區補充...
這些標記用于將頁面分成多個部分。熟練地掌握這些標記將意味著構建出具有良好的結構和布局的頁面,使其更加友好和易于閱讀。
div標記定義了HTML文件中的一個部分或分區。它通常包含需要組合在一起的標題、段落、表格或其他元素。通過設置<div class="">與css一起使用來設置網頁某個部分的顯示。
p標記用來定義文本的段落,就像你在書中看到的那樣,一旦文本達到屏幕邊緣就會自動折到下一行。當另一個<p>標記用于開始下一個段落時,瀏覽器將在段落之間添加一些空白。p標記具有以下屬性:
span標記用于將內聯元素組合在一起,例如句子中的幾個單詞,以便僅對這些單詞應用css樣式。span標記可以在div和p標記中使用,因為它不會創建新的塊。
br標記相當于一個回車符,用于在新行開始文本。一行中的多個<br>標記將在網頁上創建一個很大的垂直空間。
hr標記通常被稱為HTML行分隔符標記,創建一條通常用于視覺上分隔頁面的水平線。它具有以下屬性:
出于某種原因,你希望文本在一條直線上繼續,而不是在屏幕的邊緣換行,可以使用nobr。注意:這將迫使用戶向右滾動以查看行的其余部分,這是一種糟糕的設計。
下面是以上標記的示例:
瀏覽器顯示內容如下所示:
本標簽: 32
例:
<dl>
<dt>標題1</dt>
<dd>內容11</dd>
<dd>內容12</dd>
<dt>標題2</dt>
<dd>內容21</dd>
<dd>內容22</dd>
</dl>
target="...",決定鏈接源在什么地方顯示(用戶自定義的名字,_blank,_parent,_self,_top);
rel="...",發送鏈接的類型;
rev="...",保存鏈接的類型;
accesskey="...",指定該元素的熱鍵;
shape="...",允許我們使用已定義的形狀定義客戶端的圖形鏡像(default,rect,circle,poly);
coord="...",使用像素或者長度百分比來定義形狀的尺寸;
tabindex="...",使用定義過的tabindex元素設置在各個元素之間的焦點獲取順序(使用tab鍵使元素獲得焦點).
action="...",接收數據的服務器的URL;
method="...",HTTP的方法(get,,post),其中get是被反對使用的;
enctype="...",指定MIME(Internet媒體類型);
onsubmit="...",當提交表單時發生的內部事件;
noreset="...",在重新設置表單時發生的內部事件;
target="...",決定把內容顯示在什么地方(_blank,_parent,_self,_top)
disabled="...",把按鈕的狀態設置為不能;
name="...",按鈕的控制名,value="...",按鈕的值;
type="...",按鈕的類型(button,,submit,,reset);
type="...",用于輸入控件的類型(text,password,checkbox,radio,submit,reset,file,hidden,image,button);
name="...",控件的控制名(要求是除了submit和reset之外的任何名字);
value="...",控件的初始值;
checked="...",把一個單選鈕設置為選中的狀態;
disabled="...",把控件的狀態設置為不能使用;
readonly="...",只對輸入密碼的文本框使用;
size="...",表示以像素為單位的除了文本框和密碼框控件之外的其它控件的寬度,它是用來指定字符的數目;
src="...",一個圖像控件的URL;
maxlength="...",指定可以輸入的最多的字符數目;
alt="...",另外一種文本描述;
usemap="...",到客戶端圖形鏡像的URL;
align="...",被反對.控制對齊方式(left,,center,,right,,justify);
tabindex="...",通過定義的tabindex值確定在不同元素之間獲得焦點的順序;
onfocus="...",當元素獲得焦點時發生的事件;
onblur="...",當元素失去焦點時發生的事件;
onselect="...",當元素被選中時發生的事件;
onchang="...",當元素狀態被改變時發生的事件;
accept="...",允許上載的文件類型.
scr="...",定義在幀中顯示的內容的來源;
frameborder="...",定義幀之間的邊界(0或1);
align="...",被反對,控制對齊方式(left,,center,,right,,justify);
height="...",幀的高度,width="..."幀的寬度;
*請認真填寫需求信息,我們會在24小時內與您取得聯系。