我正在创建一个WordPress插件,我有一个自定义元框,其中包含一些复选框。现在我想在页面刷新后保存这些复选框的状态,因此我这样做:
<script type="text/javascript">
(function() {
var boxes = document.querySelectorAll("input[name='my_meta_box_check[]']");
for (var i = 0; i < boxes.length; i++) {
var box = boxes[i];
if (box.hasAttribute("value")) {
setupBox(box);
}
}
function setupBox(box) {
var storageId = box.getAttribute("value");
var oldVal = localStorage.getItem(storageId);
box.checked = oldVal === "true" ? true : false;
box.addEventListener("change", function() {
localStorage.setItem(storageId, this.checked);
});
}
})();
</script>
它有效。但是,无论何时创建新帖子,都会使用上一篇文章中的旧值检查复选框。首次创建帖子时,如何刷新或取消选中所有复选框?如果帖子状态尚未发布,我也尝试从数据库中删除post meta,如下所示:
if(get_post_status($post->ID)==='publish'){
echo "<b>"."Post is published!"."</b></br>";
}
else
{
global $wpdb;
global $post;
echo "<b>"."Post is not published!"."</b></br>";
$wpdb->query("DELETE from wp_postmeta where post_id LIKE '$post->ID' AND meta_key='my_meta_box_check'");
}
它执行查询,但使用上一篇文章中的值检查复选框。
提交帖子后,您需要清除本地存储空间。
如果要从本地存储中删除/清除所有值而不是使用
localStorage.clear();
如果要从本地存储中删除特定项而不是使用以下代码
localStorage.removeItem(key);