remove() empty() after()

本文介绍了jQuery中remove(), empty(), after()等方法的功能及用法,包括如何使用这些方法来删除DOM元素、清空元素内容以及在选定元素后插入内容。此外,还提供了一个通用的替换方法实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

remove()----从页面DOM里删除包装集所有元素。需要注意的是从DOM里删除的元素仍然被该包装集引用着。

empty()-----清空匹配集里所有dom元素的内容

after()-------after() 方法在被选元素后插入指定的内容。

如:

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $("button").click(function(){
    $("p").after("<p>Hello world!</p>");
  });
});
</script>
</head>
<body>
<p>This is a paragraph.</p>
<button>在每个 p 元素后插入内容</button>
</body>
</html>
------------------------------------------------

This is a paragraph.

--------------------------------------------------

This is a paragraph.

Hello world!

-------------------------------------------------------------

可以利用remove()和after()方法进行替换操作

如: $("p").after("<p>Hello world!</p>");改写为

 $("p").after("<p>Hello world!</p>").remove();

则如下图;

Hello world!

---------------------------自己的一个感悟:一直认为$("p").after("<p>Hello world!</p>")到这里后会返回一个包装集合然后执行remove()方法后会全部去掉,不过仔细看了after()函数它不返回包装集的只是个操作,所以针对remove操作的还是原来的包装集 不知道对不这样理解

 

针对上述替换可以写出来一个通用的方法如下;
$.fn.rplaceWith=function(html){

   return this.after(html).remove();

}

so the full code would be // Store selected items in session before checkout add_action('wp_ajax_store_selected_items', 'store_selected_items'); add_action('wp_ajax_nopriv_store_selected_items', 'store_selected_items'); function store_selected_items() { check_ajax_referer('woocommerce-cart', 'security'); if (isset($_POST['selected_items'])) { WC()->session->set('selected_checkout_items', $_POST['selected_items']); wp_send_json_success(); } wp_send_json_error(); } // Filter cart contents to only include selected items during checkout add_filter('woocommerce_get_cart_contents', 'filter_cart_contents_for_checkout', 20, 1); function filter_cart_contents_for_checkout($cart_contents) { // Only on checkout page if (is_checkout() && !is_wc_endpoint_url('order-received')) { $selected_items = WC()->session->get('selected_checkout_items'); if (!empty($selected_items)) { $filtered_contents = array(); foreach ($cart_contents as $key => $item) { if (in_array($key, $selected_items)) { $filtered_contents[$key] = $item; } } return $filtered_contents; } } return $cart_contents; } // 修改原 remove_selected_items_after_checkout 函数 function remove_selected_items_after_checkout($order_id) { $selected_items = WC()->session->get('selected_checkout_items'); if (!empty($selected_items)) { foreach ($selected_items as $cart_item_key) { WC()->cart->remove_cart_item($cart_item_key); } // 清除会话数据(关键!) WC()->session->__unset('selected_checkout_items'); // 手动触发购物车更新(确保未选中商品保留) WC()->cart->calculate_totals(); } } // Clear session data WC()->session->__unset('selected_checkout_items'); // AJAX remove selected items add_action('wp_ajax_remove_selected_cart_items', 'remove_selected_cart_items'); add_action('wp_ajax_nopriv_remove_selected_cart_items', 'remove_selected_cart_items'); function remove_selected_cart_items() { check_ajax_referer('woocommerce-cart', 'security'); if (isset($_POST['selected_items'])) { foreach ($_POST['selected_items'] as $cart_item_key) { WC()->cart->remove_cart_item(sanitize_text_field($cart_item_key)); } wp_send_json_success(); } wp_send_json_error(); } // Clear entire cart add_action('wp_ajax_clear_entire_cart', 'clear_entire_cart'); add_action('wp_ajax_nopriv_clear_entire_cart', 'clear_entire_cart'); function clear_entire_cart() { check_ajax_referer('woocommerce-cart', 'security'); WC()->cart->empty_cart(); wp_send_json_success(); } // Remove cart totals section add_action('template_redirect', 'remove_cart_totals_section'); function remove_cart_totals_section() { if (is_cart()) { remove_action('woocommerce_cart_collaterals', 'woocommerce_cart_totals', 10); } } // Enqueue necessary scripts add_action('wp_enqueue_scripts', 'partial_checkout_scripts'); function partial_checkout_scripts() { if (is_cart()) { wp_localize_script('wc-cart', 'wc_cart_params', array( 'ajax_url' => admin_url('admin-ajax.php'), 'cart_nonce' => wp_create_nonce('woocommerce-cart') )); } } // Restore original cart if checkout is abandoned add_action('template_redirect', 'restore_original_cart_if_abandoned'); function restore_original_cart_if_abandoned() { if (is_cart() && WC()->session->get('selected_checkout_items')) { // Clear the session to prevent filtering on next checkout attempt WC()->session->__unset('selected_checkout_items'); } } add_action('woocommerce_init', 'override_woocommerce_cart'); function override_woocommerce_cart() { if (!class_exists('WC_Cart') || !WC()->session) return; // 关键修复:检查 session 是否存在 class WC_Cart_Custom extends WC_Cart { public function empty_cart($force_session = false) { // 安全检查:确保 session 已初始化 if (WC()->session && WC()->session->get('selected_checkout_items')) { return; } parent::empty_cart($force_session); } } // 替换全局 cart 实例 $GLOBALS['woocommerce']->cart = new WC_Cart_Custom(); } correct?
最新发布
08-01
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值