前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[Lua 自定义函数调用]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
CSS
...们使用了 p 标签来定义段落格式,使用 text-indent 属性配置首个行首个行缩进。 需要注意的是,text-indent 只对块元素有效,对于内联元素是无效的。如果想要内联元素的文本也首个行缩进,需要将其配置为块元素。 还有一种比较特殊情形,就是针对符号或数字列的样式。我们可以使用 list-style 属性来配置符号或数字列的样式,其中包含了一个 list-style-position 属性。这个属性可以用来配置符号或数字列的位置,包含 内部、外部 和 继承 三个取值。其中,我们可以使用 内部 取值来实现首个行缩进符号或数字列的效果。 下面是一个示例编程,达成一个首个行缩进标记列的效果: ul { list-style: none; margin: 0; padding: 0; } li:before { content: "•"; display: inline-block; width: 1em; text-align: center; margin-left: -1em; } li { text-indent: -2em; padding-left: 2em; } 可以看到,我们首先用 list-style: none 去除标记列的样式,然后通过 li:before 定义了一个符号元素(这里使用了实心圆点作为符号),并使用 text-indent 属性和 padding-left 属性来实现首个行缩进的效果。 总结一下,在 CSS 中,我们可以使用 text-indent 属性来实现段落首个行首个行缩进的效果,也可以使用 list-style-position 属性来实现符号或数字列的首个行缩进效果。这些简单的样式技巧能够让我们轻松地实现更加美观、易读的排版效果。
2023-02-27 22:17:26
523
逻辑鬼才
Linux
...ython编程环境中定义了一组目录列表。当Python解释器试图导入一个模块时,会按照PYTHONPATH中列出的路径顺序进行搜索,以找到对应的模块文件。在Linux系统中,通过设置PYTHONPATH可以扩展Python默认的搜索路径,使得解释器能够在自定义的目录下查找和导入所需的模块。 虚拟环境(venv或conda) , 虚拟环境是Python开发中用于隔离项目依赖的一种工具。venv是Python自带的虚拟环境管理器,而conda则是Anaconda发行版提供的更强大的环境管理工具。它们允许开发者为每个独立的项目创建一个纯净的Python运行环境,其中包含特定版本的Python解释器及项目所需的各种第三方库。这样可以避免不同项目间因库版本冲突带来的问题,同时也便于项目的部署和迁移。 PEP 582提案 , “Path-based module import”(基于路径的模块导入)是PEP 582提案的核心内容,该提案旨在改进Python的模块导入机制。在Python 3.9及更高版本中,这个提案允许开发者直接从文件系统的指定路径中导入模块,增强了对大型项目和复杂模块层次结构的支持,简化了模块管理和组织方式,使代码更加灵活和易于维护。
2023-03-09 18:38:16
107
时光倒流_t
JQuery
...供了许多高级功能,如自定义图表样式、实时刷新数据、异步加载数据等,进一步增强了企业的数据可视化效果。 //基本用法 $('div').echarts({ option: { //echarts图表配置项 title: { text: '某产品销售情况', subtext: '数据来自国家统计局' }, tooltip: {}, legend: { data: ['销量'] }, xAxis: { data: ["1月", "2月", "3月", "4月", "5月", "6月"] }, yAxis: {}, series: [{ name: '销量', type: 'bar', data: [5, 20, 36, 10, 10, 20] }] } }); 上述代码展示了如何使用jQuery插件echarts创建一个简单的柱状图。首先,通过$('div').echarts()选择对应的容器,并传入echarts图表配置项option。接着,通过option配置项设置图表的基本属性和数据,如标题、坐标轴、系列等。 企业可以根据自己的实际需求和数据特点,调整echarts图表的相关属性和样式,达到最佳效果。使用这个强大的数据可视化工具,企业可以更好地监控关键业务指标、发现异常数据并采取相应措施,提高业务决策的效率与准确度。
2024-04-28 16:11:37
297
代码侠
JSON
...据载体,还支持丰富的自定义类型系统,以满足日益复杂的应用场景需求。此外,诸如AJAX、RESTful API等技术也都深度依赖JSON进行前后端数据交互。 与此同时,考虑到性能优化和数据压缩的问题,业界也出现了对JSON的改进方案。比如,Facebook推出的Msgpack是一种二进制序列化格式,它在保持类似JSON语法简洁性的同时,显著提高了数据传输效率。另外,JSONB(Binary JSON)是PostgreSQL数据库为存储和检索JSON数据而提供的高效二进制格式。 不仅如此,针对JSON的安全性问题,开发者需关注如何有效验证和过滤JSON数据,防止注入攻击等安全风险。为此,一些库如ajv、 Joi等提供了严谨的数据模式验证功能,确保接收到的JSON数据符合预期结构和类型。 综上所述,深入理解和掌握JSON相关的最新技术和最佳实践,对于提升应用程序的数据处理能力、保障数据交互安全以及优化系统性能等方面具有重要价值。建议读者持续关注JSON及相关领域的发展趋势,并结合具体项目需求灵活运用各种解决方案。
2023-05-11 17:44:41
267
代码侠
Java
...于处理对象引用和方法调用的重要性。为进一步探究Java编程领域的最新动态和高级应用,可以延伸阅读以下内容: 近期,Java社区发布了一个关于Java 17(LTS版本)的更新,其中引入了全新的“sealed classes”(密封类)特性,这一特性允许开发者限制哪些类能够继承某个类,从而增强了对类型系统和代码安全性的控制。在实际编码中,结合this关键字,开发者可以更精确地定义和操作对象,进一步提升程序的可维护性和安全性。 此外,对于面向对象设计原则的理解也能深化对this关键字使用的领悟。例如,在"Effective Java"一书中,作者Joshua Bloch强调了方法内使用this关键字来明确指代当前对象属性的重要性,以避免潜在的命名冲突问题。他还探讨了this在构造器链式调用、匿名内部类以及枚举类中的特殊应用场景,这些内容为读者提供了更广阔的视角去审视和运用this关键字。 同时,随着函数式编程思想在Java中的逐渐普及,如Java 8引入的Lambda表达式和Stream API,this关键字在这些新特性的上下文中也展现出了新的用法和价值。通过研读相关教程和实战案例,开发者能更好地将传统的面向对象编程与现代函数式编程范式相结合,实现代码逻辑的简洁高效表达。 综上所述,无论是跟进Java的新版本特性、深入研究经典著作中的设计原则,还是探索函数式编程在Java中的实践,都能帮助开发者从不同维度深化对this关键字及其实战应用的理解。
2023-02-16 20:21:01
348
诗和远方_t
Java
...。 实例变量是在类中定义的变量,它们可以被整个类中的方法所调用。实例变量的生存期与实例一致,即唯有建立了实例之后,实例变量才生效。实例变量划分为类变量和非类变量。 public class Person { //非类变量 String name; int age; //类变量 static String gender; } 临时变量只在其所在的代码块中生效范围。当代码块执行完毕,临时变量就会被销毁。临时变量可以在方法中定义,也可以在代码块中定义。 public class Test { public void method() { //在方法中定义临时变量 int num = 10; if(num >5) { //在代码块中定义临时变量 String str = "Hello"; } //num和str都不能在代码块以外调用 } } 需要注意的是,在方法中定义的参数也是临时变量,它们只在方法执行时生效范围。 正确地使用实例变量和临时变量可以让程序更加清晰和灵活,提高代码的可读性和可维护性。
2023-07-02 10:26:04
287
算法侠
JSON
...中,使用了反引号来定义Go数据结构中每个成员的数据类型和JSON属性名称的映射关系。在这里,我们还可以看到,在address成员中嵌套了一个数据结构,以映射层次化的JSON数据。
2024-01-12 17:00:16
530
码农
转载文章
...carte或其他工具自定义Linux桌面菜单布局,不仅可以提升日常工作效率,还能彰显个性。实际上,Linux系统的强大之处就在于其开放性和自由度,允许用户根据自己的喜好调整系统每一处细节,从而打造出真正符合个人习惯的工作或娱乐环境。 综上所述,无论是从最新的Linux发行版动态,还是到未来桌面环境发展趋势,抑或是鼓励用户发挥创意进行个性化定制,都在不断强调Linux世界的核心价值——自由、灵活和无限可能性。
2023-07-04 22:18:47
80
转载
Element-UI
...我们需要在data中定义一个函数,用于手动触发change事件。例如: javascript export default { data() { return { selected: null, options: [ { value: '选项1', label: '选项1' }, { value: '选项2', label: '选项2' }, { value: '选项3', label: '选项3' } ] }; }, methods: { changeHandler() { this.$refs['yourSelect'].$el.dispatchEvent(new Event('change')); } } }; 注意,这里的yourSelect是你el-select组件的ref名称。你需要将其替换为你自己的el-select组件的ref名称。 3. 最后,我们需要在提交表单之前调用这个函数。例如: javascript this.changeHandler(); this.$refs.yourForm.validate((valid) => { if (valid) { // 表单验证通过,可以提交表单 } else { // 表单验证未通过,不能提交表单 } }); 这里假设你的el-form组件的ref名称为yourForm。 五、结论 以上就是解决el-select组件在Element-UI中无法正常触发验证事件的方法。虽然这个方法步骤稍微繁琐了点,不过只要你按照我刚才说的一步步来,保准你能顺利解决问题,妥妥的搞定它!希望这篇文章能够帮助到正在为这个问题困扰的朋友们。
2023-07-29 10:10:20
420
素颜如水_t
HTML
...开发中, 常作为自定义组件的外壳,承载组件内部结构与样式,并通过Shadow DOM技术实现封装与复用。而则在ARIA角色标注中起到关键作用,帮助提升网站的无障碍性,为视觉障碍用户提供更精确的文本描述和导航提示。 同时,随着CSS Grid布局和Flexbox布局的广泛应用, 元素不再仅限于传统的块级容器功能,它能够构建出更加灵活和动态的网格布局。而CSS3新增的选择器和属性,让在实现精细文本样式控制的同时,也支持更多的交互状态样式设定。 进一步探究,现代前端框架如React、Vue等对DOM操作的抽象,使得开发者在使用 和时,更多地关注于数据驱动视图更新的理念,而非直接操作DOM本身。这些新的开发范式和技术趋势,无疑赋予了 和元素更深层次的含义与可能性,值得每一位前端开发者持续关注并深入学习实践。
2023-10-10 08:03:49
503
心灵驿站-t
VUE
...js中,我们可以通过自定义组件来实现将应用各部分分割成单独的、可重复使用的部分。Vue.js还提供命令,它们可以用来简化DOM操作,使我们可以更加专注于信息和业务逻辑。 // Vue.js组件示例 Vue.component('my-component', { template: ' Hello, world! ' }); Vue.js已成为广受欢迎的前端框架之一,它相对于Angular和React具有更小的体积和更快的速度。Vue.js的作者尤雨溪(Yuxi You)曾经说过,将“vue”作为框架的名称是因为这个单词非常简洁、易于拼写和搜索。 虽然“vue”在法语中的意思是“视图”,但在Vue.js中,它则代表着一种前端开发的新思想:将应用拆分成可复用的组件,通过信息绑定和命令实现信息驱动的视图渲染。Vue.js的这种简洁、易用、高效的特性,也正是其在开发者中赢得广泛关注和好评的原因之一。
2023-12-22 14:31:59
63
逻辑鬼才
MySQL
...程性,使其能够扩展和自定义,以适应不同的需求。 2. MySQL Cluster:MySQL Cluster是一个基于InnoDB存储引擎的面向事务的分散式数据库系统。它使用自己的数据节点和数据复制技术,实现平滑的水平扩展,提供高可用性和高可扩展性,支持分散式事务和分区表。MySQL Cluster尤其适合处理实时的在线业务应用,如电信、金融、电子商务等。 总之,MySQL的分散式是现代互联网应用的必备技术之一,它可以提高MySQL的可扩展性和高效能,同时也增加了系统的稳定性和可用性。对于需要处理大量读写请求和海量数据存储的应用,MySQL的分散式是一个非常好的解决方案。
2023-02-25 16:35:15
123
逻辑鬼才
Docker
...Dockerfile自定义自己的Docker映像,并通过docker build命令来创建映像。 示例:使用Dockerfile创建一个简单的Java Web应用映像 新建一个名为“myjavaapp”的目录,并在该目录下新建一个名为“Dockerfile”的文件 FROM tomcat:8.5.60-jdk8-openjdk-slim-buster COPY ./myapp.war /usr/local/tomcat/webapps/ 上述Dockerfile基于Tomcat 8.5.60-jdk8-openjdk-slim-buster映像创建映像。将myapp.war文件复制到/usr/local/tomcat/webapps/目录下,使得该Java Web应用可以在Tomcat虚拟环境中启动。 Docker已经发展成为一个庞大的生态圈,提供众多应用和技术栈的虚拟环境化,例如Kubernetes、Swarm、Mesos等。使用Docker可以优化应用的开发、安装和运维过程,提高应用的稳定性和扩展性。
2024-01-10 21:35:41
463
代码侠
AngularJS
...otScope 上定义的任何属性或函数都可以被应用程序内的任何地方访问到。当出现“noctrl Controller 0 not found”这样的错误时,意味着AngularJS在尝试从 $rootScope 找寻并初始化一个名为“0”的控制器时失败。 angular.module() , 在AngularJS中,angular.module() 是用于创建和获取模块的核心方法。模块是AngularJS应用的基本构建块,负责组织相关组件(如控制器、指令、服务等)。通过调用该方法,开发者可以声明一个新的模块或者引用已经存在的模块,并在其上添加或配置各种组件,例如在示例代码中,myModule.controller( MyCtrl , function($scope) ... )就是在myApp模块中注册了一个名为MyCtrl的控制器。 angular.bootstrap() , 这是一个启动AngularJS应用程序的方法。在HTML文档加载完成后,开发者使用 angular.bootstrap() 方法来手动初始化指定的DOM元素,并告诉AngularJS使用哪个模块来启动应用。在给出的文章示例中,angular.bootstrap(document, myApp ) 表示将整个文档(document)作为应用的根元素,并使用名为 myApp 的模块来启动和编译整个应用程序。这样,AngularJS就可以开始解析DOM中的指令和表达式,执行相应的业务逻辑,并与用户进行交互。
2024-01-18 15:53:01
430
春暖花开-t
Python
...供了一种简洁的方式来定义路由(如 /submit-form ),处理HTTP请求(如POST方法提交的表单数据),并能够方便地从请求对象(request)中获取表单字段信息。开发者通过Flask可以快速构建功能完备且具有良好扩展性的Web应用程序。 ORM(Object-Relational Mapping)框架 , ORM是一种将关系型数据库的数据与程序中的对象进行映射的技术框架。在文中提及的场景中,ORM框架可以帮助开发者以面向对象的方式操作数据库,例如将用户输入的表单数据转换为模型对象,并自动执行SQL语句将其持久化存储到数据库中,从而简化了数据库操作,提高开发效率和代码可读性。 请求方法(methods= POST ) , 在Web开发中,HTTP协议定义了一系列请求方法,其中POST方法是用来向指定资源提交数据进行处理(例如在表单提交时)。在Flask框架中,@app.route装饰器的methods参数用于指定该路由能够响应哪些HTTP请求方法。这里的 methods= POST 表示只有当客户端发起POST请求时, /submit-form 这个URL路径下的函数才会被调用处理请求数据。 request.form , 在Flask框架中,request对象封装了来自客户端的所有HTTP请求信息。request.form是其中的一个属性,它提供了对请求体中编码为 application/x-www-form-urlencoded 或 multipart/form-data 格式数据的访问。在处理表单提交时,可以通过request.form field_name 来获取表单中特定字段(如username和password)的用户输入值。
2023-10-31 17:23:22
282
码农
Docker
...ockerfile 定义的,Dockerfile 可以认为是 Docker 容器的构建蓝图,其中描述了容器镜像的组成。以下是一个 Dockerfile 的样例: 使用 official Node.js 镜像作为父镜像 FROM node:10 设置容器启动时要运行的命令 CMD ["node", "index.js"] 将本地文件夹挂载到容器内的 /app 目录中 WORKDIR /app COPY . /app 在容器中运行 npm install 安装应用所需的依赖 RUN npm install Docker 通过镜像来封装应用程序及其所有依赖项,从而使部署变得更加简单,因为只需部署一个镜像即可。例如,如果我们需要部署一个 Node.js 应用程序,只需从 Docker Hub 中下载 Node.js 镜像,并将应用程序和 package.json 文件一起封装成一个镜像。 总之,在使用 Docker 部署应用程序时,我们只需要定义应用程序的镜像,然后将镜像部署到任何支持 Docker 的服务器上即可。这使得应用程序的部署和运行变得非常简单、可靠和可重复。
2023-01-30 11:42:25
445
数据库专家
JSON
...on.dumps()函数将data转换为JSON格式。在请求结束后,我们通过assert断言判断请求的返回状态码和JSON数据是否符合预期。如果测试案例执行成功,则代表接口调用正常。 总的来说,JSON程序化测试可以帮助我们实现快速、可靠和缩短测试时间等诸多优点。同时需要注意JSON格式的数据,需要符合规范,否则在数据处理环节中可能会出现意想不到的错误。
2023-12-07 16:32:59
499
软件工程师
转载文章
...cription: 自定义异常 / public class UnSupportedShapeException extends Exception { public UnSupportedShapeException(String message) { super(message); } }/ Description: 客户端 / public class DrawingTool { public static void main(String[] args) { Shape s1, s2, s3, s4; try { s1 = ShapeFactory.createShape("圆形"); s2 = ShapeFactory.createShape("方形"); s3 = ShapeFactory.createShape("三角形"); s1.draw(); s1.erase(); s2.draw(); s2.erase(); s3.draw(); s3.erase(); // s4.draw(); // s4.erase(); } catch (Exception e) { System.out.println(e.getMessage()); } } } 本篇文章为转载内容。原文链接:https://blog.csdn.net/Luoxiaobaia/article/details/120300797。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-07-27 10:54:19
110
转载
Element-UI
...个Flex容器,负责定义子元素(Col)的排列方式以及对齐方式。 html 1.2 Col组件 Col组件则代表栅格系统中的每一列,通过span属性可以指定当前列占据的栅格数,从而实现灵活的布局分配。 2. 响应式布局实践 Element-UI的布局组件支持响应式设计,可以根据不同的屏幕尺寸自动调整布局。 html 3. 更多高级用法 除了基本的行与列布局外,我们还可以利用offset属性进行列偏移,或者通过push和pull属性调整列的显示顺序。 html 4. 思考与探讨 使用Element-UI的布局组件时,我常常惊叹于它的简洁与高效。通过直观的API,我们可以快速实现从简单到复杂的各种布局需求。同时呢,响应式设计这个理念也让我特别有感触,尤其是在现在这个手机党横行的时代,我明白了根据不同的设备和屏幕尺寸去精心打磨用户体验是多么关键的一件事。 不过,值得注意的是,尽管布局组件功能强大,但过度依赖或不恰当的使用可能会导致代码过于冗余或难以维护。所以在实际做项目的时候,咱们就得瞅准具体的业务环境,灵活挑选拿捏这些组件,让界面设计既养眼又和谐,同时也把代码结构整得井井有条。 总结一下,Element-UI布局组件是我们前端工程师手中的利器,掌握好它,你就能随心所欲地塑造出千变万化的页面布局,让设计之美与技术之力完美融合。在实践中不断思考和探索,你会发现更多关于布局设计的乐趣与奥秘!
2023-10-30 14:41:05
416
桃李春风一杯酒
Docker
...容器指的是基于官方或自定义MySQL镜像运行的一个独立的、具有完整MySQL数据库服务功能的Docker容器实例。通过在容器内部安装并运行MySQL服务器,用户可以在不依赖于宿主机具体环境的情况下,快速搭建和管理MySQL数据库,同时借助Docker提供的资源隔离和灵活管理特性,实现对数据库服务的高效运维和扩展。 Docker Hub , Docker Hub是一个集中式仓库,提供Docker镜像的托管与分发服务。在文中,用户需要从Docker Hub上下载MySQL镜像以创建数据库容器。它不仅是全球最大的Docker镜像库,还支持用户上传自己的私有镜像,并通过版本管理和自动化构建等功能,极大地促进了容器化应用的开发和交付过程。
2024-01-12 17:40:23
536
代码侠
转载文章
... API。开发者可以自定义其属性如origins、methods等以满足特定的安全和访问控制需求。 RESTful web服务 , REST(Representational State Transfer)架构风格的web服务简称RESTful web服务,是一种软件架构风格和网络应用程序设计模式。在这种风格下,Web服务通过HTTP协议暴露资源,并使用统一接口(包括GET、POST、PUT、DELETE等HTTP方法)进行资源的创建、读取、更新和删除操作。通过URI(Uniform Resource Identifier)定位资源,并以JSON、XML等形式返回资源的状态。在本文中,通过在RESTful web服务的控制器方法上应用@CrossOrigin注解,实现对这些服务的跨域访问支持。
2023-11-11 12:31:12
330
转载
Python
...应用价值。 莫比乌斯函数(Mobius Function) , 在数论中,莫比乌斯函数是一个定义在正整数集上的函数,记作μ(n)。对于任何正整数n,若n为质数的幂次,则μ(n)等于-1;若n含有重复质因子,则μ(n)等于0;若n为质数的乘积,则μ(n)等于+1。在文中提到的正负交替数列与莫比乌斯函数之间存在联系,这种函数可以用于素数分解、约数分析等领域。 列表(List) , 在Python编程语言中,列表是一种基本的数据结构,它可以存储一系列有序的元素,并且支持动态增删改查操作。在本文中,我们使用列表seq来存储生成的正负交替数列,通过append()方法将计算得到的新元素添加至列表末尾,从而实现序列的构建。 循环语句(Loop Statement) , 在编程中,循环语句是一种控制结构,允许程序根据条件重复执行一段代码。在本文所给出的Python代码片段中,使用了for循环语句,从1遍历到参数n,每次迭代时更新数列元素的正负值并将其追加到列表seq中,直至完成指定长度的正负交替数列的创建。 函数(Function) , 在编程中,函数是一段可重用的代码块,接受输入参数并产生输出结果。本文介绍了一个名为alternating_sequence()的函数,该函数接收一个参数n,基于此参数值生成一个长度为n的正负交替数列,展示了Python中如何定义和使用函数以封装特定逻辑,方便后续调用和复用。
2023-01-27 13:46:53
343
电脑达人
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
systemctl start|stop|restart|status service_name
- 管理systemd服务。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"