1
0
mirror of https://github.com/php/doc-zh.git synced 2026-03-24 07:02:15 +01:00
Files
archived-doc-zh/language/predefined/stringable.xml
2024-12-01 23:27:50 +08:00

112 lines
3.2 KiB
XML
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?xml version="1.0" encoding="utf-8"?>
<!-- $Revision$ -->
<!-- EN-Revision: 85050f5f88cca909b14b7cccc1dcedbb784a4fd6 Maintainer: mowangjuanzi Status: ready -->
<reference xml:id="class.stringable" role="class" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude">
<title>Stringable 接口</title>
<titleabbrev>Stringable</titleabbrev>
<partintro>
<!-- {{{ Stringable intro -->
<section xml:id="stringable.intro">
&reftitle.intro;
<para>
<interfacename>Stringable</interfacename> 接口表示拥有
<link linkend="object.tostring">__toString()</link> 方法的类。
和大多数接口不同, <interfacename>Stringable</interfacename> 隐式存在于任何定义了
<link linkend="object.tostring">__toString()</link> 魔术方法的类上,
当然也可以显式声明它,并且推荐这么做。
</para>
<para>
它的主要价值是能让函数针对简单的字符串或可以转化为字符串的对象,检测联合类型 <literal>string|Stringable</literal>
</para>
</section>
<!-- }}} -->
<section xml:id="stringable.synopsis">
&reftitle.interfacesynopsis;
<!-- {{{ Synopsis -->
<classsynopsis class="interface">
<oointerface>
<interfacename>Stringable</interfacename>
</oointerface>
<classsynopsisinfo role="comment">&Methods;</classsynopsisinfo>
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.stringable')/db:refentry/db:refsect1[@role='description']/descendant::db:methodsynopsis[@role='Stringable'])">
<xi:fallback/>
</xi:include>
</classsynopsis>
<!-- }}} -->
</section>
<section xml:id="stringable.examples">
<title>Stringable 示例</title>
<para>
<example xml:id="stringable.basic-example">
<title>基础 Stringable 用法</title>
<simpara>这里使用了<link linkend="language.oop5.decon.constructor.promotion">构造器属性提升</link></simpara>
<programlisting role="php">
<![CDATA[
<?php
class IPv4Address implements Stringable {
public function __construct(
private string $oct1,
private string $oct2,
private string $oct3,
private string $oct4,
) {}
public function __toString(): string {
return "$this->oct1.$this->oct2.$this->oct3.$this->oct4";
}
}
function showStuff(string|Stringable $value) {
// 存在 Stringable这将默认调用 __toString()。
print $value;
}
$ip = new IPv4Address('123', '234', '42', '9');
showStuff($ip);
?>
]]>
</programlisting>
&example.outputs.similar;
<screen>
<![CDATA[
123.234.42.9
]]>
</screen>
</example>
</para>
</section>
</partintro>
&language.predefined.stringable.tostring;
</reference>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->