【Linux命令行与Shell脚本编程】第十六章 Shell函数

Linux命令行与Shell脚本编程

第一章


文章目录

  • Linux命令行与Shell脚本编程
  • 六.函数
    • 6.1.脚本函数基础
      • 6.1.1.创建函数
      • 6.1.2.使用函数
    • 6.2.函数返回值
      • 6.2.1.默认的退出状态码
      • 6.2.2.使用return命令
      • 6.2.3.使用函数输出
    • 6.3.函数中使用变量
      • 6.3.1.向函数传递参数
      • 6.3.2.在函数中处理变量
        • 全局变量
        • 局部变量
    • 6.4.数组变量和函数
      • 6.4.1.向函数中传递数组
      • 6.4.2.从函数返回数组
    • 6.5.函数递归
    • 6.6.创建库
    • 6.7.在命令行中使用函数
      • 6.7.1.命令行中创建函数
    • 6.7.2.在.bashrc文件中定义函数
    • 6.8.共享库函数
      • 6.8.1.下载安装


六.函数

  • 脚本函数基础
  • 函数返回值
  • 在函数中使用变量
  • 数组变量和函数
  • 函数递归
  • 创建库
  • 在命令行中使用函数

可以将shell脚本代码放入函数中封装起来,这样就能在脚本的任意位置多次使用.

6.1.脚本函数基础

函数是一个脚本代码块,可以并在脚本中的任何位置重用它。当需要在脚本中使用该代码块时,直接通过函数名调用.

6.1.1.创建函数

bash shell脚本中创建函数的语法有两种。

  • 使用关键字function
function name {//函数的唯一名称。脚本中的函数名不能重复commands //组成函数的一个或多个bash shell命令。  
}
  • 近其他编程语言中定义函数的方式
name() {//函数名后的空括号表明正在定义的是一个函数
commands
}

6.1.2.使用函数

使用函数名调用函数

$ cat test1
#!/bin/bash
# using a function in a script
function func {echo "This is an example of a function"
}
count=1
while [ $count -le 5 ]
dofunccount=$[ $count + 1 ]
done
$ ./test1
This is an example of a function
This is an example of a function
This is an example of a function
This is an example of a function
This is an example of a function
  • 函数定义不一定非要放在shell脚本的最开始部分,但必须定义在调用之后,在函数被定义之前调用,则会收到一条错误消息.
func: command not found
  • 如果定义了同名函数,新定义就会覆盖函数原先的定义,而不会有任何错误消息.

6.2.函数返回值

bash shell把函数视为一个小型脚本,运行结束时会返回一个退出状态码.

有3种方法能为函数生成退出状态码。

6.2.1.默认的退出状态码

函数的退出状态码是函数中最后一个命令返回的退出状态码。函数执行结束后,可以使用标准变量 $? 来确定函数的退出状态码.

  • 函数执行一结束就立刻读取返回值。用$?变量提取函数返回值之前执行了其他命令,函数的返回值会丢失。
#!/bin/bash
func1() {## 命令执行失败ls -l badfile
}
echo "testing the function: "
func1
echo "The exit status is: $?"
testing the function:
trying to display a non-existent file
ls: badfile: No such file or directory
The exit status is: 1

退出状态码是1,因为函数中的最后一个命令执行失败.使用函数的默认退出状态码是一种危险的做法.
ps: 函数最执行成功退出状态码为0.

6.2.2.使用return命令

bash shell会使用return命令以特定的退出状态码退出函数。return命令允许指定一个整数值作为函数的退出状态码.

$ cat test5
#!/bin/bash
# using the return command in a functionfunction dbl {read -p "Enter a value: " valueecho "doubling the value"return $[ $value * 2 ]
}dbl
echo "The new value is $?"
$
$ ./test5
Enter a value: 200
doubling the value
The new value is 1
$

大于255的任何数值都会产生错误的值.

6.2.3.使用函数输出

需要返回较大的整数值或字符串,可以将函数的’输出’保存到shell变量中.

result=$(function_name)
$ cat test5b
#!/bin/bash
# using the echo to return a value
function dbl {read -p "Enter a value: " valueecho $[ $value * 2 ]
}
result=$(dbl)
echo "The new value is $result"
$
$ ./test5b
Enter a value: 200
The new value is 400
$
$ ./test5b
Enter a value: 1000
The new value is 2000
$

函数会用echo语句来显示计算结果。脚本会获取dbl函数的输出,而不是查看退出状态码。
dbl函数实际上输出了两条消息。read命令输出了一条简短的消息来向用户询问输入值。
bash shell并不将其作为STDOUT输出的一部分,而是直接忽略。
如果用echo语句生成这条消息("Enter a value: ")来询问用户,消息就会与输出值一起被读入shell变量。
借助返回值方法,还可以返回浮点值和字符串.

6.3.函数中使用变量

在函数中使用变量时,需要注意变量的定义方式和处理方式。

6.3.1.向函数传递参数

bash shell会将函数当作脚本来对待。可以像普通脚本那样向函数传递参数.
函数名保存在$0变量中,函数参数依次保存在$1、 2 等变量中 . 可以用特殊变量 2等变量中.可以用特殊变量 2等变量中.可以用特殊变量#来确定传给函数的参数数量.
(处理用户输入章节)

脚本中调用函数时,必须将参数和函数名放在同一行.然后用位置变量来获取参数值。

func_name $value1 10

示例:

$ cat test6
#!/bin/bash
function addem {if [ $# -eq 0 ] || [ $# -gt 2 ]thenecho -1elif [ $# -eq 1 ]thenecho $[ $1 + $1 ]elseecho $[ $1 + $2 ]fi
}echo -n "Adding 10 and 15: "
value=$(addem 10 15)
echo $value
echo -n "Let's try adding just one number: "
value=$(addem 10)
echo $value
echo -n "Now try adding no numbers: "
value=$(addem)
echo $value
echo -n "Finally, try adding three numbers: "
value=$(addem 10 15 20)
echo $value
$
$ ./test6
Adding 10 and 15: 25
Let's try adding just one number: 20
Now try adding no numbers: -1
Finally, try adding three numbers: -1

函数使用位置变量访问函数参数,无法直接获取脚本的命令行参数。

$ cat badtest1
#!/bin/bash
# trying to access script parameters inside a functionfunction badfunc1 {echo $[ $1 * $2 ]
}if [ $# -eq 2 ]
thenvalue=$(badfunc1)echo "The result is $value"
elseecho "Usage: badtest1 a b"
fi
$
$ ./badtest1
Usage: badtest1 a b
$ ./badtest1 10 15
./badtest1: *  : syntax error: operand expected (error token is "*")
The result is
$

尽管函数使用了$1变量和$2变量,但和脚本主体中的$1变量和$2变量不同。
要在函数中使用脚本的命令行参数,必须在调用函数时手动将其传入.

value=$(badfunc1 $1 $2)

在将$1和$2传给函数后就能跟其他变量一样供函数使用。

6.3.2.在函数中处理变量

变量的作用域是比较麻烦的.作用域是变量的有效区域.
函数有两种类型的变量:

  • 全局变量
  • 局部变量

全局变量

在shell脚本内任何地方都有效的变量。
在默认情况下,在脚本中定义的任何变量都是全局变量。在函数外定义的变量可在函数内正常访问.

$ cat test8
#!/bin/bash
function dbl {value=$[ $value * 2 ]
}
read -p "Enter a value: " value
dbl
echo "The new value is: $value"
$
$ ./test8
Enter a value: 450
The new value is: 900

$value变量在函数外定义并被赋值。如果变量在函数内被赋予了新值,那么在脚本中引用该变量时,新值仍可用。

局部变量

在任何在函数内部使用的变量都可以被声明为局部变量.local关键字保证了变量仅在该函数中有效。

  • 在变量声明之前加上local关键字.
  • 在变量赋值语句中使用local关键字.
local temp
local temp=$[ $value + 5 ]

如果函数之外有同名变量,两个变量的值互不干扰。

function func1 {local temp=$[ $value + 5 ]result=$[ $temp * 2 ]
}

6.4.数组变量和函数

在函数中使用数组变量.

6.4.1.向函数中传递数组

将数组变量当作单个参数传递不起作用.
数组变量作为函数参数进行传递,则函数只会提取数组变量的第一个元素。

$ cat badtest3
#!/bin/bash
function testit {echo "The parameters are: $@"thisarray=$1echo "The received array is ${thisarray[*]}"
}
myarray=(1 2 3 4 5)
echo "The original array is: ${myarray[*]}"
testit $myarray
$
$ ./badtest3
The original array is: 1 2 3 4 5
The parameters are: 1
The received array is 1

必须先将数组变量拆解成多个数组元素,然后将这些数组元素作为函数参数传递。最后在函数内部,将所有的参数重新组合成一个新的数组变量。

$ cat test11
#!/bin/bash
function addarray {local sum=0local newarraynewarray=(`echo "$@"`)for value in ${newarray[*]}dosum=$[ $sum + $value ]doneecho $sum
}
myarray=(1 2 3 4 5)
echo "The original array is: ${myarray[*]}"
arg1=$(echo ${myarray[*]})
result=$(addarray $arg1)
echo "The result is $result"
$
$ ./test11
The original array is: 1 2 3 4 5
The result is 15

6.4.2.从函数返回数组

函数向shell脚本返回数组变量先用echo语句按正确顺序输出数组的各个元素,脚本再将数组元素重组成一个新的数组变量.

$ cat test12
#!/bin/bash
function arraydblr {local origarraylocal newarraylocal elementslocal iorigarray=($(echo "$@"))newarray=($(echo "$@"))elements=$[ $# - 1 ]for (( i = 0; i <= $elements; i++ )){newarray[$i]=$[ ${origarray[$i]} * 2 ]}echo ${newarray[*]}
}
myarray=(1 2 3 4 5)
echo "The original array is: ${myarray[*]}"
arg1=$(echo ${myarray[*]})
result=($(arraydblr $arg1))
echo "The new array is: ${result[*]}"
$
$ ./test12
The original array is: 1 2 3 4 5
The new array is: 2 4 6 8 10

通过$arg1变量将数组元素作为参数传给arraydblr函数。
arraydblr函数将传入的参数重组成新的数组变量,生成数组变量的副本。对数据元素进行操作,并将结果存入函数中的数组变量副本。

6.5.函数递归

函数可以递归地调用.
递归函数通常有一个最终可以迭代到的基准值。
递归算法的经典例子是计算阶乘:

$ cat test13
#!/bin/bash
function factorial {if [ $1 -eq 1 ]thenecho 1elselocal temp=$[ $1 - 1 ]local result=$(factorial $temp)echo $[ $result * $1 ]fi
}
read -p "Enter value: " value
result=$(factorial $value)
echo "The factorial of $value is: $result"
$
$ ./test13
Enter value: 5
The factorial of 5 is: 120

6.6.创建库

使用函数可以为脚本省去一些重复性的输入工作.如果要在多个脚本中使用同一段代码,通过库解决.
bash shell允许创建函数库文件,然后在多个脚本中引用此库文件。

  1. 创建一个包含脚本中所需函数的公用库文件。
    $ cat myfuncs
    function addem {echo $[ $1 + $2 ]
    }
    function multem {echo $[ $1 * $2 ]
    }
    
  2. 在需要用到这些函数的脚本文件中包含myfuncs库文件.
    shell函数的作用域和环境变量一样,shell函数仅在定义它的shell会话内有效。
    如果在shell命令行界面运行myfuncs脚本,那么shell会创建一个新的shell并在其中运行这个脚本。
    这种情况下,函数会定义在新shell中,当运行另一个要用到这些函数的脚本时,它们是无法使用的。
    如果尝试像普通脚本文件那样运行库文件,函数也不会出现在脚本中.
    $ cat badtest4
    #!/bin/bash
    # using a library file the wrong way
    ./myfuncs
    result=$(addem 10 15)
    echo "The result is $result"
    $
    $ ./badtest4
    ./badtest4: addem: command not found
    The result is
    
    使用函数库的关键在于source命令。
    source命令不会创建新的shell,而是在当前shell的上下文中执行命令.
    source命令称作点号操作符。在shell脚本中运行myfuncs库文件,只需添加:
    . ./myfuncs
    
    假定myfuncs库文件和shell脚本位于同一目录。否则需要使用正确路径访问该文件。
    $ cat test14
    #!/bin/bash
    . ./myfuncs
    value1=10
    value2=5
    result1=$(addem $value1 $value2)
    echo "The result of adding them is: $result1"
    $
    $ ./test14
    The result of adding them is: 15
    

6.7.在命令行中使用函数

有时候,在命令行界面用函数执行一些十分复杂的操作.

6.7.1.命令行中创建函数

shell会解释用户输入的命令,可以在命令行中直接定义一个函数.
在命令行创建函数时要特别小心。如果给函数起了一个跟内建命令或另一个命令相同的名字,那么函数就会覆盖原来的命令。

  • 单行方式
    在命令行中定义函数时,必须在每个命令后面加个分号,用于界定命令的起止.
    $ function divem { echo $[ $1 / $2 ];  }
    $ divem 100 5
    20
    
  • 多行方式
    定义时,bash shell会使用次提示符’>'来提示输入更多命令。使用这种方法,无须在每条命令的末尾放置分号,只需按下回车键.
    输入函数尾部的花括号后完成函数的定义.
    $ function multem {
    > echo $[ $1 * $2 ]
    > }
    $ multem 2 5
    10
    

在命令行中直接定义shell函数的一个明显缺点是,在退出shell时,函数也会消失。
在命令行创建函数时要特别小心。如果给函数起了一个跟内建命令或另一个命令相同的名字,函数就会覆盖原来的命令。

6.7.2.在.bashrc文件中定义函数

解决退出shell函数消失的问题.
将函数定义在每次新shell启动时都会重新读取该函数的地方。
.bashrc文件,不管是交互式shell还是从现有shell启动的新shell,bash shell在每次启动时都会在用户主目录中查找这个文件。

  1. 直接定义函数
    直接在用户主目录的.bashrc文件中定义函数。将函数放在文件末尾.
    $ cat .bashrc
    # .bashrc
    # Source global definitions
    if [ -r /etc/bashrc ]; then. /etc/bashrc
    fi
    function addem {echo $[ $1 + $2 ]
    }
    $
    
    函数会在下次启动新的bash shell时生效。随后就能在系统中的任意地方使用这个函数。
  2. 源引函数文件
    只要是在shell脚本中,就可以用source命令(或别名即点号操作符)将库文件中的函数添加到.bashrc脚本中.确保库文件的路径名正确.
    $ cat .bashrc
    # .bashrc
    # Source global definitions
    if [ -r /etc/bashrc ]; then. /etc/bashrc
    fi
    . /home/rich/libraries/myfuncs
    $
    

shell会将定义好的函数传给子shell进程,这些函数就能够自动用于该shell会话中的任何子shell脚本.
用源引库文件,这些函数就可以在shell脚本中顺畅运行。

6.8.共享库函数

在开源世界中,共享代码是必不可少的,同样适用于shell脚本函数。可以下载各种shell脚本函数并将其用于自己的应用程序中。
下载、安装以及使用GNU shtool shell脚本函数库。shtool库提供了一些简单的shell脚本函数,可用于实现日常的shell功能,比如处理临时文件和目录、格式化输出显示等。

6.8.1.下载安装

  1. 将GNU shtool库下载并安装到你的系统中.
    wget http://ftp.gnu.org/gnu/shtool/shtool-2.0.8.tar.gz
    
  2. 将文件复制到主目录中.
  3. 使用tar命令提取文件.
    tar -zxvf shtool-2.0.8.tar.gz
    
  4. 进入到解压新创建的目录
  5. 构建库文件
    使用标准的configure命令和make命令
    $ ./configure
    $ make
    

configure命令会检查构建shtool库文件所必需的软件。发现了所需的工具,会使用工具路径修改配置文件。
make命令负责构建shtool库文件。最终的shtool文件是一个完整的库软件包文件。
可以使用make命令测试库文件

$ make test
Running test suite:
echo...........ok
... ...OK: passed: 19/19

测试模式会测试shtool库中所有的函数。如果全部通过了测试,就可以将库安装到Linux系统中的公用位置,这样你的所有脚本就都能使用这个库了。
以root用户使用make命令的install选项完成安装.

# make install
Password:
./shtool mkdir -f -p -m 755 /usr/local
... ...
./shtool install -c -m 644 sh.version /usr/local/share/shtool/sh.version
./shtool install -c -m 644 sh.path /usr/local/share/shtool/sh.path
# shtool -v
GNU shtool 2.0.8 (18-Jul-2008)

安装成功,可以使用了.

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/80352.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OLED透明屏拼缝技术:创新的显示解决方案

引言&#xff1a;OLED透明屏作为一种创新的显示技术&#xff0c;已经在各个领域展现出了巨大的潜力。而其中的拼缝技术更是为OLED透明屏的应用带来了全新的可能性。 对此&#xff0c;尼伽便大家具体介绍一下OLED透明屏拼缝技术的概念、优势以及应用领域&#xff0c;并探讨其在…

JVM之类加载与字节码(二)

3. 编译期处理 什么是语法糖 所谓的 语法糖 &#xff0c;其实就是指 java 编译器把 *.java 源码编译为 *.class 字节码的过程中&#xff0c;自动生成 和转换的一些代码&#xff0c;主要是为了减轻程序员的负担&#xff0c;算是 java 编译器给我们的一个额外福利&#xff08;给…

C高级 作业 day4 8/7

1.整理思维导图 2.写一个函数&#xff0c;获取用户的uid和gid并使用变量接收 3.整理冒泡排序、选择排序和快速排序的代码 冒泡排序 //冒泡排序 void bubble_sort(int a[],int len) {int count0;for(int i1;i<len;i) //控制轮数{for(int j0;j<len-i;j) //控制每一轮交换…

flex 弹性布局

Flex 布局的使用 任何一个容器都可以指定为 Flex 布局。 .box{ display: flex; //flex作为display的一个属性使用 } 行内元素也可以使用 Flex 布局。 .box{ display: inline-flex; } 注意&#xff1a;设为 Flex 布局以后&#xff0c;子元素的float、clear和vertical-align…

Java_理解方法调用

理解方法调用 首先什么是隐式参数 --->隐式参数是调用该方法的对象本身。 接下来方法的名称和参数列表被称为方法的签名&#xff08;signature&#xff09;。在Java中&#xff0c;方法的签名由方法的名称和参数列表组成&#xff0c;用于唯一标识一个方法。返回类型不是签名的…

Mysql存储引擎InnoDB

一、存储引擎的简介 MySQL 5.7 支持的存储引擎有 InnoDB、MyISAM、Memory、Merge、Archive、Federated、CSV、BLACKHOLE 等。 1、InnoDB存储引擎 从MySQL5.5版本之后&#xff0c;默认内置存储引擎是InnoDB&#xff0c;主要特点有&#xff1a; &#xff08;1&#xff09;灾难恢…

【MCU学习】GD32F427VG开发

&#xff08;一&#xff09;学习文档和例程 兆易创新GD32 MCU参考资料下载 1.GD232F4xx的Keil芯片支持包 2.标准固件库和示例程序 3.GD32F4xx_固件库使用指南_Rev1.2 4.用户手册&#xff1a;GD32F4xx_User_Manual_Rev2.8_CN 5.数据手册&#xff1a;GD32F427xx_Datasheet_Rev…

SpringMVC的注解

文章目录 前言前期准备ResponseBody 返回JSONRequestMapping 映射控制器GetMapping、PostMapping 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; SpringMVC框架只需要少量的配置即可快速实现Web应用程序开发&#xff0c;不需要大量的XML配置文件。 不…

电脑第一次使用屏幕键盘

操作流程 1.在键盘上同时按WinR打开运行; 2.输入control 3.找到设置中心 4.点击屏幕键盘 效果 具体怎么使用 我不咋清除 简单 测试了一下 可以用鼠标点击屏幕键盘的按键 用键盘 按字母键和数字键 是和屏幕键盘不同步的 其他 tab、shift、后退、enter好像同步

分立式BUCK电路原理与制作持续更新

一、分立式BUCK电路总体原理图 下面改图包含了电压环和电流环。 二、BUCK电路与LDO的区别 LDO不适合在压差大的环境下使用&#xff0c;因为三极管因为CE极承受了压差&#xff0c;压差越大损耗的功率就越大&#xff0c;将三极管换成MOS管&#xff0c;MOS管两端的压差很小所以效…

梳理日常开发涉及的负载均衡

负载均衡是当前分布式微服务时代最能提及的词之一&#xff0c;出于对分层、解耦、弱依赖、可配置、可靠性等概念的解读&#xff0c;一对一的模式变得不再可信赖&#xff0c;千变万化的网络环境中&#xff0c;冗余和备份显得格外重要&#xff0c;稍大型的系统就会存在大量微服务…

TextBrewer:融合并改进了NLP和CV中的多种知识蒸馏技术、提供便捷快速的知识蒸馏框架、提升模型的推理速度,减少内存占用

TextBrewer:融合并改进了NLP和CV中的多种知识蒸馏技术、提供便捷快速的知识蒸馏框架、提升模型的推理速度&#xff0c;减少内存占用 TextBrewer是一个基于PyTorch的、为实现NLP中的知识蒸馏任务而设计的工具包&#xff0c; 融合并改进了NLP和CV中的多种知识蒸馏技术&#xff0…

C高级-day4

#!/bin/bash function fun1(){arr[0]id -u $1arr[1]id -g $1echo ${arr[*]} }arr(fun1 ubuntu) echo ${arr[*]}冒泡排序 void Maopao(int arr[],int len){for(int i1;i<len;i){int count0;for(int j0;j<len-i;j){if(arr[j]>arr[j1]){int tarr[j];arr[j]arr[j1];arr[j…

智能优化算法——哈里鹰算法(Matlab实现)

目录 1 算法简介 2 算法数学模型 2.1.全局探索阶段 2.2 过渡阶段 2.3.局部开采阶段 3 求解步骤与程序框图 3.1 步骤 3.2 程序框图 4 matlab代码及结果 4.1 代码 4.2 结果 1 算法简介 哈里斯鹰算法(Harris Hawks Optimization&#xff0c;HHO)&#xff0c;是由Ali…

如何解决 Elasticsearch 查询缓慢的问题以获得更好的用户体验

作者&#xff1a;Philipp Kahr Elasticsearch Service 用户的重要注意事项&#xff1a;目前&#xff0c;本文中描述的 Kibana 设置更改仅限于 Cloud 控制台&#xff0c;如果没有我们支持团队的手动干预&#xff0c;则无法进行配置。 我们的工程团队正在努力消除对这些设置的限制…

arcgis宗地或者地块四至权利人信息提取教程

ARCGIS怎样将图斑四邻的名称及方位加入其属性表 以前曾发表过一篇《 如何把相邻图斑的属性添加在某个字段中》的个人心得,有些会员提出了进一步的要求,不但要相邻图斑的名称,还要求有方位,下面讲一下自己的做法。 基本思路是:连接相邻图斑质心,根据连线的角度确定相邻图斑…

c++游戏制作指南(三):c++剧情类文字游戏的制作

&#x1f37f;*★,*:.☆(&#xffe3;▽&#xffe3;)/$:*.★* &#x1f37f; &#x1f35f;欢迎来到静渊隐者的csdn博文&#xff0c;本文是c游戏制作指南的一部&#x1f35f; &#x1f355;更多文章请点击下方链接&#x1f355; &#x1f368; c游戏制作指南&#x1f3…

21、p6spy输出执行SQL日志

文章目录 1、背景2、简介3、接入3.1、 引入依赖3.2、修改database参数&#xff1a;3.3、 创建P6SpyLogger类&#xff0c;自定义日志格式3.4、添加spy.properties3.5、 输出样例 4、补充4.1、参数说明 1、背景 在开发的过程中&#xff0c;总希望方法执行完了可以看到完整是sql语…

供水管网漏损监测,24小时保障城市供水安全

供水管网作为城市生命线重要组成部分&#xff0c;其安全运行是城市建设和人民生活的基本保障。随着我国社会经济的快速发展和城市化进程的加快&#xff0c;城市供水管网的建设规模日益增长。然而&#xff0c;由于管网老化、外力破坏和不当维护等因素导致的供水管网漏损&#xf…

js修改img的src属性显示变换图片到前端页面,img的src属性显示java后台读取返回的本地图片

文章目录 前言一、HTML 图像- 图像标签&#xff08; <img>&#xff09;1.1图像标签的源属性&#xff08;Src&#xff09;1.2图像标签源属性&#xff08;Src&#xff09;显示项目中图片1.3图像标签源属性&#xff08;Src&#xff09;显示网络图片 二、图像标签&#xff08…