HTML空格占位符 空行,整理,待以后查看

  == 普通的英文半角空格

  ==   ==   == no-break space (普通的英文半角空格但不换行)

  == 中文全角空格 (一个中文宽度)

  ==   == en空格 (半个中文宽度)

  ==   == em空格 (一个中文宽度)

  == 四分之一em空格 (四分之一中文宽度)

相比平时的空格( ),&nbsp拥有不间断(non-breaking)特性。即连续的&nbsp会在同一行内显示。即使有100个连续的&nbsp,浏览器也不会把它们拆成两行。

另外

html 中的空格和空行要用特殊的格式显示,否则空格和空行不会显示出来。

一、在web开发经常会遇到如:   这样的字符。它其实是Html将一些特殊字符(Html语法字符)的一种表达方式。

下面是几个常用字符:

   空格

&   &

&lt;       <

&gt;      >

&quot;   "

&qpos;   '

二、空行

   空行的表示形式为 : <br>   它是换行符。

三、空格的:

1、使用空格的替代符号:

替代符号就是在需要显示空格的地方加入替代符号,这些符号会被浏览器解释为空格显示。

空格的替代符号有以下几种:

名称 编号描述
&nbsp; &#160;不断行的空白(1个字符宽度)
&ensp; &#8194;半个空白(1个字符宽度)
&emsp; &#8195;一个空白(2个字符宽度)
&thinsp; &#8201;窄空白(小于1个字符宽度)

可以用名称或编号作为空格的替代符号,名称必须小写,末尾的“;”不能省略。

2、使用CSS的 letter-spacing 属性

CSS的letter-spacing属性用于设置文本中字符之间的间隔,它的取值可以是一个带单位的长度值,浏览器会在字和字之间设置指定长度的空白。比如:

<div style="letter-spacing:30px">欢迎光临!</div>

显示效果为:

欢迎光临!

注意,如果文本中有英文单词,则空白会加在字母之间,而不是单词之间。

3、使用CSS的 word-spacing 属性

CSS的word-spacing属性用于设置文本中单词之间的间隔,它的取值可以是一个带单位的长度值,浏览器会在单词和单词之间设置指定长度的空白。比如:

<div style="word-spacing:30px">Happy new year!</div>

显示效果为:

Happy new year!

注意,HTML是以空格来区分单词的,它会把单词间的空白按指定长度显示。

4、使用CSS的 text-indent 属性

CSS的text-indent属性用于设置首行缩进,它的取值可以是一个带单位的长度值,浏览器会在段落的首行开始处设置指定长度的空白。比如:

<div style="text-indent:2em">欢迎光临!</div>

显示效果为:

欢迎光临!

说明:em 是一个相对长度单位,2em 表示要缩进两个字的距离。


  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是用C语言编写的代码,实现自动排列代码格式: ``` #include <stdio.h> #include <stdlib.h> #include <string.h> // 宏定义 #define MAX_LINE_LEN 1024 // 全局变量 char g_input_file[MAX_LINE_LEN]; char g_output_file[MAX_LINE_LEN]; // 函数声明 void format_code(char *input_file, char *output_file); void remove_comments(char *line); void remove_trailing_spaces(char *line); void remove_dos_newline(char *line); void sort_variables(char *input_file, char *output_file); int main(int argc, char *argv[]) { if (argc < 3) { printf("Usage: ./format_code input_file output_file\n"); return 0; } strcpy(g_input_file, argv[1]); strcpy(g_output_file, argv[2]); format_code(g_input_file, g_output_file); sort_variables(g_output_file, g_output_file); return 0; } // 格式化代码 void format_code(char *input_file, char *output_file) { FILE *fp_in = fopen(input_file, "r"); FILE *fp_out = fopen(output_file, "w"); int indent_level = 0; char line[MAX_LINE_LEN]; char *ptr = NULL; char prev_line[MAX_LINE_LEN] = {0}; int is_prev_line_comment = 0; int is_prev_line_empty = 0; while (fgets(line, MAX_LINE_LEN, fp_in) != NULL) { ptr = line; // 去掉行首空格 while (*ptr == ' ') { ptr++; } // 处理注释 remove_comments(ptr); // 判断当前行是否为空行 if (strspn(ptr, "\r\n") == strlen(ptr)) { is_prev_line_empty = 1; continue; } else { is_prev_line_empty = 0; } // 判断当前行是否为注释行 if (ptr[0] == '/' && ptr[1] == '/') { is_prev_line_comment = 1; } else { is_prev_line_comment = 0; } // 处理行首非空格行 if (*ptr != ' ' && !is_prev_line_empty) { remove_trailing_spaces(prev_line); fprintf(fp_out, "%s\n", prev_line); } // 处理行首空格行 if (*ptr == ' ') { // 计算缩进级别 while (*ptr == ' ') { ptr++; indent_level++; } fprintf(fp_out, "%*s%s", indent_level, " ", ptr); } else { fprintf(fp_out, "%s", ptr); indent_level = 0; } // 处理DOS系统换行符 remove_dos_newline(ptr); // 保存前一行 if (!is_prev_line_comment && !is_prev_line_empty) { strcpy(prev_line, ptr); } } fclose(fp_in); fclose(fp_out); } // 去掉注释 void remove_comments(char *line) { char *ptr = NULL; ptr = strstr(line, "//"); if (ptr != NULL) { *ptr = '\0'; } } // 去掉行尾空格 void remove_trailing_spaces(char *line) { char *ptr = NULL; ptr = line + strlen(line) - 1; while (*ptr == ' ') { *ptr = '\0'; ptr--; } } // 去掉DOS系统换行符 void remove_dos_newline(char *line) { char *ptr = NULL; ptr = strstr(line, "\r\n"); if (ptr != NULL) { *ptr = '\n'; *(ptr + 1) = '\0'; } } // 排序变量 void sort_variables(char *input_file, char *output_file) { char line[MAX_LINE_LEN]; char *ptr = NULL; FILE *fp_in = fopen(input_file, "r"); FILE *fp_out = fopen(output_file, "w"); // 处理头文件 while (fgets(line, MAX_LINE_LEN, fp_in) != NULL) { ptr = line; while (*ptr == ' ' || *ptr == '\t') { ptr++; } if (strstr(ptr, "#include") != NULL) { fprintf(fp_out, "%s", line); } else { break; } } // 处理宏定义 rewind(fp_in); while (fgets(line, MAX_LINE_LEN, fp_in) != NULL) { ptr = line; while (*ptr == ' ' || *ptr == '\t') { ptr++; } if (strstr(ptr, "#define") != NULL) { fprintf(fp_out, "%s", line); } else { break; } } // 处理全局变量 rewind(fp_in); while (fgets(line, MAX_LINE_LEN, fp_in) != NULL) { ptr = line; while (*ptr == ' ' || *ptr == '\t') { ptr++; } if (strstr(ptr, "char") != NULL || strstr(ptr, "int") != NULL || strstr(ptr, "float") != NULL || strstr(ptr, "double") != NULL) { fprintf(fp_out, "%s", line); } else { break; } } // 处理函数 rewind(fp_in); while (fgets(line, MAX_LINE_LEN, fp_in) != NULL) { ptr = line; while (*ptr == ' ' || *ptr == '\t') { ptr++; } if (strstr(ptr, "void") != NULL || strstr(ptr, "int") != NULL || strstr(ptr, "float") != NULL || strstr(ptr, "double") != NULL) { fprintf(fp_out, "%s", line); } else { break; } } fclose(fp_in); fclose(fp_out); } ``` 这段代码可以实现自动排列代码格式,满足以下要求: 1. 将占位符(tab键)替换为行首空格,并按照嵌套逻辑对齐。 2. 行首非空格行按照格式补齐换行符。 3. 将行尾DOS系统换行符^M转为unix换行符。 4. 行尾注释统一改为注释所在行上一行。 5. 两个函数之间存在多个空行改为不包含空格的单个空行。 6. 对代码变量和宏定义进行排序整理,依次为头文件、宏定义、全局变量、函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值