douyun1950 2017-03-12 15:22
浏览 13
已采纳

如何在搜索表单中插入跨度? (创)

When I call genesis_search_form(), it outputs:

<form class="search-form">
  <meta itemprop="target">
  <input type="search">
  <input type="submit">
</form>

But I wanted it to generate with a span inside, like:

<form class="search-form">
  <meta itemprop="target">
  <input type="search">
  <span class="submit-icon"></span>
  <input type="submit">
</form>

Was looking for a safer alternative to:

add_filter( 'genesis_search_form', 'my_search_button' ); 
function my_search_button( $form ) {
    return str_replace( 
        '<input type="submit"', 
        '<span class="submit-icon"></span><input type="submit"', 
        $form 
    );
}

To avoid replacing the start of a tag. Any ideas?

  • 写回答

3条回答 默认 最新

  • dty98339 2017-03-16 18:11
    关注

    If you are okay with DOMDocument, this version works better for HTML5.

    add_filter( 'genesis_search_form', 'my_search_button' );
    function my_search_button($form) {
    
        $document = new DOMDocument();
        $document->loadHTML($form);
        $xpath = new DOMXPath($document);
        $input = $xpath->query('//input[@type="submit"]');
        $span = $document->createElement('span');
        $span->setAttribute('class', 'sb-icon');
    
        if ($input->length > 0) {
            $input->item(0)->parentNode->insertBefore($span, $input->item(0));
        }
    
        $document->removeChild($document->doctype); 
        $document->replaceChild($document->firstChild->firstChild->firstChild, $document->firstChild);
        $form_html = $document->saveHTML();
    
        return $form_html;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况
  • ¥15 画两个图 python或R