- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
p.s. had placed this simply to share the solution.
如果我们在 js 中使用 ajax 单击一个按钮,我想在前端保存一个帖子:
var title = $("#portfolioTitle").val();
var customFieldValues = $("#customfieldValue").val();
$("#btnClick").on("click", function() {
$.ajax({
url : ajax_url,
type: 'post',
dataType: 'json',
data: {
action: 'data_Publish', portfolioTitle: title, fieldValues: customFieldValues
},
success: function(data) {
if(data == "exists") {
console.log("Add a different title");
} else {
console.log("post added");
console.log(data["link"]);
console.log(data["title"]);
}
}
});
});
最佳答案
放置我自己的答案但想知道是否有任何速度或安全改进?
例如我们可以添加一个缓存系统,或者define our own ajax (也许可以提供帮助:How to implement the code in the link using the case scenario using the case scenario we have on this question?)为了不让 wordpress 加载所有文件,但在这里我们正在做一个http 请求,无论如何,如果你们中的任何人愿意付出他们的 2 美分以使其更快,那就太好了。
假设我们想要在 wordpress 前端通过 ajax 添加帖子,并且我们想要检查标题在数据库中是否唯一,否则告诉用户添加不同的标题:
我们有一个按钮可以点击:
<button type="button" id="btnClick">Load</button>
我们有标题输入和自定义字段:
<input type="text" id="portfolioTitle" name="portfolioTitle" value="" placeholder="Your title...">
<input type="text" id="customfieldValue" name="customfieldValue" value="" placeholder="Your customFieldvalue...">
JS。首先,您需要加载 wordpress ajax(如果有人愿意,可以改进这一点):
var ajax_url = '<?php echo admin_url( 'admin-ajax.php' ); ?>';
然后是您的javaScript:
var title = $("#portfolioTitle").val();
var customFieldValues = $("#customfieldValue").val();
$("#btnClick").on("click", function() {
$.ajax({
url : ajax_url,
type: 'post',
dataType: 'json',
data: {
action: 'data_Publish', portfolioTitle: title, fieldValues: customFieldValues
},
success: function(data) {
if(data == "exists") {
console.log("Add a different title");
} else {
console.log("post added");
console.log(data["link"]);
console.log(data["title"]);
}
}
});
});
然后在 function.php
中:
function data_Publish() {
$post_title = $_POST['portfolioTitle'];
$post_custom_field = $_POST['fieldValues'];
$post = array(
'post_title' => $post_title,
'post_status' => 'publish',
'post_type' => 'page',
'page_template' => 'portoflio.php'
);
if ( get_page_by_title( $post_title ) === null ) {
// the title is unique, we can add the new page
$post_id = wp_insert_post( $post );
add_post_meta($post_id, 'customField', $post_custom_field], true);
$link = get_permalink( get_page_by_title( $post_title ) );
$title = get_the_title($post_id);
$newPostAttributes[] = array("link"=>$link, "title"=>$title);
echo json_encode($newPostAttributes);
} else {
// that title already exists, tell the user to change it
echo json_encode("exists");
}
wp_die();
}
add_action('wp_ajax_data_Publish', 'data_Publish');
基本上该函数是一个普通的 wordpress 查询
。因此,如果您愿意,您可以使用相同的逻辑来检索帖子值,例如,您不会使用 $post_id = wp_insert_post( $post );
但也许可以将标题恢复为您将使用 $postTile = get_the_title();
的用户。
让我们分解一下:
在 ajax 中,我们使用 action: 'data_Publish', portfolioTitle: title
其中 data_Publish
是我们的 php 函数
,而 portfolioTitle: title
是我们发送的内容。
在函数中我们可以看到:$post_title = $_POST['portfolioTitle'];
这是我们通过 ajax
发送的标题。使用 'page_template' => 'portoflio.php'
我们可以将我们自己的模板添加到该页面。
然后我们需要使用 if ( get_page_by_title( $_POST['portfolioTitle'] ) === null ) {
来检查该标题是否存在,如果不存在,我们使用 $post_id = wp_insert_post( $post );
添加它后,我们使用以下命令将任何其他值添加到新创建的帖子中的自定义字段add_post_meta($post_id, 'customField', $_POST['customfieldValue'],
其中customField
是我们要在刚刚添加的新帖子中创建的自定义字段的名称。
因此,如果帖子不存在,我们会保存它,我们可以将它的标题和链接发送回 ajax
,这样我们就可以将它作为响应显示给用户,如果我们愿意永远想要。
所以我们这样定义标题和链接,我们创建一个多维
数组来将数据发送回前端:
$link = get_permalink( get_page_by_title( $post_title ) );
$title = get_the_title($post_id);
$newPostAttributes[] = array("link"=>$link, "title"=>$title);
如果标题存在,我们会发回一个响应 echo json_encode("exists");
为了安全我们需要终止查询 wp_die();
如果我们想让任何登录用户都可以使用 ajax,记住 wordpress ajax 只对管理员可用,所以我们需要添加:
add_action('wp_ajax_data_Publish', 'data_Publish');
add_action( 'wp_ajax_nopriv_data_Publish', 'data_Publish' );
基本上在 function.php wordpress
中使用 wp_ajax_ +"name of our function"
并且 wordpress 有 wp_ajax_nopriv_
使 ajax 在没有记录时可用.
我希望它对任何人都有帮助,如果你们中的任何人可以改进它,它对所有人来说都会更好。
关于javascript - 如何在 wordpress 前端使用 ajax 保存帖子和自定义字段值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57455584/
我正在尝试将我所有的东西从 videomarathon.com/dk 导入到 videomarathon.com/se(帖子等) 我正在使用 wordpress 导入器。 上传导出的文件时,它向我显示
Azure WordPress 和 Azure 可扩展 WordPress 之间有什么区别?除了可扩展的 WordPress 允许您选择 azure 存储之外,我看不出有什么区别 最佳答案 基本区别:
我目前正在一个与体育相关的 wordpress 网站上工作。我所有的帖子都在同一个地方,分为足球、网球等。我想改变我博客的结构,比如足球,应该是domain.com/football对于网球,应该是
Wordpress 3 有一个漂亮的 TinyMCE 实现,我相信它比它所基于的原始 TinyMCE 运行得流畅得多。 很棒的事情:- HTML/源代码 View 作为选项卡而不是弹出窗口- 有吸引力
我在 codex.wordpress.org 和developer.wordpress.org 上看到了 WordPress 开发人员文档。他们都有关于插件和主题的文档。由于我不了解 wordpres
我有自定义帖子循环,我想在底部添加“查看全部”链接,该链接应指向包含该类型所有帖子的页面。 我能想到的唯一解决方案是为帖子类型创建一个模板页面并硬编码指向它的链接,但我希望有一个更优雅和动态的解决方案
我正在尝试使用类在 WordPress 中创建自定义 REST API 端点。我也用传统方法做了同样的事情——效果很好。但是,使用类时出现错误 The handler for the route is
我是 WordPress 的新手,正在尝试在主页的一部分中使用一些自定义代码,该部分旨在显示三个类别(白皮书、文章和帖子)中每个类别的 #1 趋势帖子.代码只是显示(据我所知)最近的 3 个帖子,无论
我正在尝试在 wordpress 中设置搜索页面的样式。在 search.php 中,我可以设置大部分页面的样式,但随后的以下语句(我从未经编辑的原始页面中获得)生成了内容。
我希望得到一些帮助来解决一些让我发疯的编码问题。我更喜欢在我的 wordpress 帖子标题中写“&”而不是“and”。但是写出&符号会破坏我们的 twitter、facebook 和 google-
是否可以只重写一个类别? 我有一个类别“ 照片”,并且只针对这个类别。 我只想从/category/photos重写它至 /photos 最佳答案 您可以使用 WP Rewrite API 来实现。
我有一个托管在 www.example.com 上的网站,它是一个 Bitnami 应用程序。 我想在 www.example.com/blog 上可以访问的同一台服务器上安装另一个 bitnami
我一直在做一些测试。注意:这仅在Safari浏览器中发生。 我关闭了所有插件并激活了主题二十(而不是我的Catch Box子主题)。在此配置下,除了顶部菜单中的“主页”选项卡(在Safari中显示如下
我是一名 php 开发人员,目前正在开发一个 CMS/博客系统。我想添加一个永久链接系统,比如 WordPress。我很好奇 WordPress 如何解析永久链接。例如,如何获取 id 这样的数据和
有谁知道Wordpress有多安全? 我不知道如何定义“有多安全”。但与其他CMS系统相比,它的安全性如何? 更新: 详细说明我的项目。 我会有很多用户注册。登录后,他们将可以访问我正在开发的插件。大
是否可以授予编辑者管理主题小部件的功能?默认情况下,只有管理员可以这样做。 谢谢, 乔恩 最佳答案 恐怕您将需要使用插件来实现此目的,因为更改窗口小部件是switch_themes capabilit
我有一个在服务器上运行的多站点 wordpress,我想将我的站点转移到另一台服务器上。我通过 filezilla ftp 下载了完整的文件备份还导出了完整的数据库。 现在我将此备份导入到新服务器 (
我使用通用 HTML 标签在 WordPress 插件中创建了一个表单。我刚刚用 echo 测试了文本框提交的值,它工作正常。提交表单后,我需要在同一页面中重定向或显示成功/失败消息。表单提交后如何显
我想启用 wordpress 站点的调试日志,在 wp-config.php 中添加以下设置 /* WordPress debug mode for developers. */ define('WP
是否可以仅在前端(无需编辑 .mo/.po 文件)更改我的 wordpress 安装(WP 3.0 Multisite)的语言? 在此处更改此选项: 也会在后端更改我的语言。 有任何想法吗? 感谢您的
我是一名优秀的程序员,十分优秀!