使用 WordPress 媒体上传器来保存图像

在本系列中,我们将了解如何在实际插件中实现 wordpress 媒体上传器。本系列及其相关代码背后的想法是让我们清楚地了解它是如何工作的,我们将来如何使用它,以及如何将它融入到我们的工作中。

到目前为止,我们已经介绍了:

WordPress 媒体上传器入门使用 WordPress 媒体上传器添加和删除图像

在这些文章中,我们逐步了解了构建一个插件的过程,该插件使用 WordPress 媒体上传器将特色图像引入到我们博客文章(和页面)的页脚中。

但有一个问题:图像未保存,也未显示在其关联博客文章(或页面)的内容中。

在本文中,我们将继续我们上次停下的地方,并完成该插件其余部分的实现。请注意,我假设您已阅读前两篇文章并了解我们迄今为止介绍的源代码。

话虽如此,让我们继续。

保存特色图像

确保图片能够在 WordPress 前端显示的关键是保存 WordPress 提供的图片信息。

在上一篇文章中,我们使用其中一些信息在我们创建的元框中显示图像,但实际上没有保存这些信息。因此,该图像无法显示在仪表板或网站前端,因为 WordPress 实际上并不记住它。

我们会解决这个问题。具体来说,我们将保存以下字段:

图像 URL,以便我们可以设置图像的 src 属性图像标题,以便我们可以将其设置为图像的 alt 属性和 title 属性

介绍元数据

我们需要做的第一件事是在插件的 admin.php 视图中添加另一个包含三个输入字段的容器。这些字段中的每一个都将对应于上面的值。

看一下下面的代码,然后我将详细说明:

从一开始,它就应该足够容易理解:

我们引入了一个由 featured-footer-image-meta 标识的容器包含三个输入文本元素,每个元素对应于我们将保存的图像元素属性

此时,我们需要跳回到 JavaScript 文件,以便我们可以获取通过媒体上传器返回给我们的信息,并使用此信息填充输入字段。

打开 admin.js,然后将以下三行添加到插入 event 的处理函数底部(对于 file_frame) :

// Store the image's information into the meta data fields$( '#footer-thumbnail-src' ).val( json.url );$( '#footer-thumbnail-title' ).val( json.title );$( '#footer-thumbnail-alt' ).val( json.title );

从这里导航到您的 WordPress 仪表板,添加新帖子或编辑现有帖子,您应该会看到如下图所示的内容:

使用 WordPress 媒体上传器来保存图像

假设您已直接编写了所有 JavaScript,则根据您在中提供的数据,您应该会看到类似的内容选择图像时的媒体上传器。

但请注意,当您单击“删除特色图像”时,文本将保留。在我们实际保存此信息之前,让我们完成 JavaScript,以便每当用户删除图像时它都会清除输入字段。

虽然有多种方法可以做到这一点,但我选择使用以下代码:

// Finally, we reset the meta data input fields$( '#featured-footer-image-info' )    .children()    .val( '' );

请记住,这需要位于“删除特色图像”锚点的事件处理程序中。在上一篇文章中,我们将此函数命名为 resetUploadForm

此时,您应该能够单击“删除精选图像”并看到图像和输入字段已重置。如果您遇到问题,请查看与本文相关的 GitHub 存储库中的源代码(它将位于 master 分支中,并且还将标记为 1.0.0)。

保存元数据

现在我们需要在插件中引入一些代码,这些代码将清理输入字段的值,将它们与帖子相关联,并将其保存到数据库中,以便我们可以在每个帖子的页脚处显示信息。

Acme_Footer_Imagerun 函数中,添加以下代码行:

add_action( 'save_post', array( $this, 'save_post' ) );

然后我们需要定义一个函数,负责将输入字段的值实际保存到数据库中。对于以下代码,有两件事需要了解:

我们会在保存数据之前对其进行清理我们将字段与用于在前端显示图像的键相关联。

/** * Sanitized and saves the post featured footer image meta data specific with this post. * * @param    int    $post_id    The ID of the post with which we're currently working. * @since 0.2.0 */public function save_post( $post_id ) {    if ( isset( $_REQUEST['footer-thumbnail-src'] ) ) {update_post_meta( $post_id, 'footer-thumbnail-src', sanitize_text_field( $_REQUEST['footer-thumbnail-src'] ) );}if ( isset( $_REQUEST['footer-thumbnail-title'] ) ) {update_post_meta( $post_id, 'footer-thumbnail-title', sanitize_text_field( $_REQUEST['footer-thumbnail-title'] ) );}if ( isset( $_REQUEST['footer-thumbnail-alt'] ) ) {update_post_meta( $post_id, 'footer-thumbnail-alt', sanitize_text_field( $_REQUEST['footer-thumbnail-alt'] ) );}}

在准备测试之前,我们需要在前端显示图像之前对仪表板视图再进行两项更改。

首先,我们需要确保将元数据回显到输入字段。跳到 admin.php 并再次更新它以包含以下内容:

在这里,我们调用 get_post_meta 函数来检索使用我们上面声明的函数保存的值。

接下来,我们需要确保使用相同的值填充本系列前面创建的图像元素:

当然,如果元数据为空,则不会填充任何内容,并且图像将不会显示。

假设一切顺利,您应该在保存帖子时看到图像及其关联数据显示在输入字段中。同样,当您删除特色图像时,字段应该清除并且不再显示。

清理

在我们继续在前端显示图像之前,我们需要做一些小事情来清理元框的显示。

首先,我们需要确保之前类型为 text 的所有输入字段均为 hidden 类型。

接下来,我们需要编写一个小的 JavaScript 函数,该函数将显示图像(假设图像已保存)。该函数将检查图像 URL 的输入字段是否不是空字符串。

如果不是,那么它将显示图像。因此,我们将此函数添加到 JavaScript 文件中:

/** * Checks to see if the input field for the thumbnail source has a value. * If so, then the image and the 'Remove featured image' anchor are displayed. * * Otherwise, the standard anchor is rendered. * * @param    object    $    A reference to the jQuery object * @since    1.0.0 */function renderFeaturedImage( $ ) {    /* If a thumbnail URL has been associated with this image     * Then we need to display the image and the reset link.     */if ( '' !== $.trim ( $( '#footer-thumbnail-src' ).val() ) ) {$( '#featured-footer-image-container' ).removeClass( 'hidden' );$( '#set-footer-thumbnail' ).parent().hide();$( '#remove-footer-thumbnail' ).parent().removeClass( 'hidden' );}}

然后,在 DOM 就绪函数的上下文中调用 JavaScript 函数:

renderFeaturedImage( $ );

简而言之,当页面加载时,它会检查输入字段中是否存在 URL。如果是这样,它会渲染图像并为我们提供删除它的选项。否则,它只显示空的特色图像框。

再次强调,如果您在执行此代码时遇到问题,请务必使用本页侧边栏中的链接查看关联的 GitHub 存储库。

显示特色图像

至此,我们已经在仪表板中完成了需要做的所有事情,现在是时候在博客的前端显示图像了。为此,我们需要设置一个连接到 the_content 操作的挂钩,检查图像是否存在,如果存在,则将其附加到帖子内容中。

为此,首先将以下行添加到 Acme_Footer_Image 类的 run 方法中:

add_action( 'the_content', array( $this, 'the_content' ) );

接下来,我们需要编写一个与此操作挂钩的函数。该函数将负责检查我们是否只是一个页面(因为如果用户有 more 标签,我们不想将图像附加到帖子的页脚其内容的一部分)。

我们使用以下代码来完成此操作:

/** * If the current post is a single post, check to see if there is a featured image. * If so, append is to the post content prior to rendering the post. * * @param   string    $content    The content of the post. * @since   1.0.0 */public function the_content( $content ) {    // We only care about appending the image to single pagesif ( is_single() ) {// In order to append an image, there has to be at least a source attributeif ( '' !== ( $src = get_post_meta( get_the_ID(), 'footer-thumbnail-src', true ) ) ) {// read the remaining attributes even if they are empty strings$alt = get_post_meta( get_the_ID(), 'footer-thumbnail-alt', true );$title = get_post_meta( get_the_ID(), 'footer-thumbnail-title', true );// create the image element within its own container$img_html = '';// append it to the content$content .= $img_html;}}return $content;}

这样,我们就应该有一个功能齐全的插件,将特色页脚图像附加到在单个帖子页面上呈现的帖子中。

结论

在本系列中,我们介绍了很多材料,其中最少涉及使用媒体上传器。尽管这篇文章花了更多时间向我们展示如何将数据从元框连接到前端,但它仍然演示了如何在插件上下文中应用媒体上传器的实际应用。

话虽如此,关于媒体上传器还有很多东西需要了解,我们可以在以后的主题中介绍这些内容。如果您有兴趣,请在下面的评论中告诉我。此外,如果您对所读内容或本系列有任何疑问,也请随时留下。

不要忘记查看该项目的 GitHub 存储库 – 我希望它能在您将来使用媒体上传器时为您提供良好的服务!

以上就是使用 WordPress 媒体上传器来保存图像的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1551366.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 21:39:28
下一篇 2025年12月21日 21:39:39

相关推荐

  • JavaScript位非(~)运算符是什么?

    按位非 (~) 运算符对位执行非运算。您可以尝试运行以下代码来了解如何使用 JavaScript 按位 NOT 运算符。 示例 document.write(“Bitwise NOT Operator”); // 7 = 00000000000000000000000000000111 docume…

    好文分享 2025年12月21日
    000
  • HTML DOM Input Radio 对象

    html dom 输入单选对象与类型为“radio”的 元素关联。我们可以分别使用 createelement() 和 getelementbyid() 方法创建和访问带有 radio 类型的输入元素。 属性 以下是输入 Radio 对象的属性 – p> Sr.No 属性和说明 1…

    2025年12月21日
    000
  • 如何在HTML中指定作者是否以及如何加载音频/视频当页面加载时?

    你可以尝试运行以下代码来学习如何实现preload属性,以便作者可以给浏览器提供最佳用户体验的提示。适用于和标签− 示例 Your browser does not support the video element. 以上就是如何在HTML中指定作者是否以及如何加载音频/视频当页面加载时?的详细内…

    2025年12月21日
    000
  • 如何在HTML中允许跨域使用图像和画布?

    为了允许跨域使用图像和画布,服务器必须在其HTTP响应中包含适当的CORS(跨域资源共享)头。这些头可以设置为允许特定的来源或方法,或者允许任何来源访问资源。 HTML Canvas An HTML5 Canvas is a rectangular area on a web page that i…

    2025年12月21日
    000
  • 如何使用HTML和CSS创建动画横幅链接

    概述 我们可以使用HTML和CSS创建动画横幅,HTML提供横幅的布局,CSS提供带有动画效果的横幅样式。有时,在为广告目的制作的横幅中,会嵌入链接,为了突出显示链接,开发人员会使链接具有动画效果,以便在整个网页内容中可见,并增加用户点击的兴趣。 语法 在 HTML 中创建链接的语法是 &#8211…

    2025年12月21日
    000
  • 如何在HTML中添加变量?

    使用 HTML 中的 标签添加变量。 HTML 标签用于格式化文档中的文本。它可以在数学表达式中包含变量。 示例 您可以尝试运行以下代码以在 HTML 中添加变量 – p> HTML var Tag The equations: 2x – 4z = 2y + 3 and x + 5…

    2025年12月21日
    000
  • 如何在HTML5中创建定义列表?

    描述列表(以前称为定义列表)提供术语及其定义的有组织的排列。 定义列表的标签如下所示:− − 这是定义列表。它将术语及其定义存储为行和数据的表格。 – 这是用于定义的术语。它使短语保持定义。 立即学习“前端免费学习笔记(深入)”; – 这用作描述或定义。它包含特定术语的定义。…

    2025年12月21日
    000
  • 当在HTML元素上按下鼠标按钮时执行脚本?

    在 HTML 中使用 onmousedown 属性在元素上按下鼠标按钮时执行脚本。 示例 您可以尝试运行以下代码来实现onmousedown属性 – This is demo heading. Click above and then release. function mouseDow…

    2025年12月21日
    000
  • 如何在HTML中指示一个段落中的潜在断词点?

    HTML的标签定义了一个可能的换行点。这代表着单词断点机会。 示例 您可以尝试运行以下代码来学习如何在HTML中实现标签 − HTML wbr Tag The browser to extend the document window beyond the size of the viewing p…

    2025年12月21日
    000
  • 我们如何在HTML中包含强调文本?

    在 HTML 中使用 标记来包含强调文本。该标签格式化文档中的文本。 示例 您可以尝试运行以下代码来了解如何在 HTML 中实现 标签 – p> HTML em Tag Simply Easy Learning. 以上就是我们如何在HTML中包含强调文本?的详细内容,更多请关注创想…

    2025年12月21日
    000
  • 根据世界标准时间,设置指定日期的完整年份

    JavaScript date setUTCFullYear()方法根据世界协调时间设置指定日期的完整年份。 setUTCFullYear(yearValue[, monthValue[, dayValue]])方法的参数如下: yearValue – 一个整数,表示年份的数值,例如20…

    2025年12月21日
    000
  • 在HTML中,如何指定表单在禁用状态时不进行验证?

    在 HTML 中,用户输入的表单是使用 以上就是在HTML中,如何指定表单在禁用状态时不进行验证?的详细内容,更多请关注创想鸟其它相关文章!

    2025年12月21日
    000
  • 引导上下文类

    Bootstrap的上下文类允许您更改表格行或单个单元格的背景颜色。 以下是类别: 类别 描述 .active 将悬停颜色应用于特定行或单元格 .success 表示成功或积极的操作 .warning 表示可能需要注意的警告 .danger 表示危险或潜在的负面操作 示例 以下是active类的示例…

    2025年12月21日
    000
  • 如何在HTML中包含字符编码?

    字符编码是一种将字节转换为字符的方法。为了正确验证或显示HTML文档,程序必须选择适当的字符编码。 使用元素来设置charset 属性,并为HTML文档指定字符编码。 Click following link Welcome to Qries 以上就是如何在HTML中包含字符编码?的详细内容,更多请…

    2025年12月21日
    000
  • 如果在JavaScript中分号放错位置会发生什么?

    如果 JavaScript 中分号放错位置,则可能会导致误导性结果。让我们看一个示例,其中 if 语句条件为 false,但由于分号放错位置,所以打印了该值。 示例 var val1 = 10; if (val1 == 15) { document.write(“Prints due to misp…

    2025年12月21日
    000
  • 当鼠标指针在HTML元素上移动时,执行一个脚本?

    在HTML中,onmouseover 属性在鼠标指针移动到元素上时触发。 示例 您可以尝试运行以下代码来实现onmouseover 属性− This is demo heading. Keep the mouse cursor on the heading to change the color. …

    2025年12月21日
    000
  • 使用JavaScript正则表达式搜索制表符

    要使用 JavaScript 正则表达式查找制表符,请使用以下命令 – t 示例 您可以尝试运行以下代码来查找制表符。它返回找到制表符 (t) 字符的位置 – JavaScript Regular Expression var myStr = “Simple t Respon…

    2025年12月21日
    000
  • 当浏览器由于任何原因无法获取媒体数据时,在HTML中执行脚本?

    使用 HTML 中的 onstalled 属性在浏览器无法获取媒体日期时执行脚本。 onstalled属性可用于以下元素 – 以下是 的语法 – 以下是 的语法 – 示例 您可以尝试运行以下代码来实现onstalled 属性 – 立即学习“前端免费学习…

    2025年12月21日
    000
  • html搜索框代码怎样写

    html搜索框代码编写步骤:1、使用标签来创建HTML表单元素来包含搜索框;2、在表单中使用标签来创建输入框,同时设置type属性为”text”,用于用户输入搜索关键字;3、使用标签创建按钮,同时设置type属性为”submit”,表示这是一个提交按钮…

    2025年12月21日
    000
  • 如何同时从左到右将函数应用于数组的两个值?

    使用JavaScript中的reduce()方法从左到右同时对数组的两个值应用函数,以将其减少为单个值。 以下是参数 – 回调– 对数组中的每个值执行的函数。initialValue − 用作回调第一次调用的第一个参数的对象。 示例 您可以尝试运行以下代码来了解如何在 Jav…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信