簡體   English   中英

一種形式取決於兩種按鈕的動作?

[英]One form two actions depending on which button?

我有兩個文件, preview.phpsave.php

<form id="create-template" class="form" action="" method="post">
    <p class="_50">
        <label for="t-name">Template name</label>
        <input type="text" name="t-name" class="required"/>
    </p>
    <p class="_100">
        <label for="t-html">Template HTML</label>
        <textarea id="t-html" name="t-html" class="required" rows="10" cols="40"></textarea>
    </p>
    <div class="clear"></div>

    <div class="block-actions">
        <ul class="actions-left">
            <li><a class="button red" id="reset-template" href="javascript:void(0);">Clear</a></li>
        </ul>
        <ul class="actions-right">
            <li><div id="preview"><input type="submit" class="button" value="Preview template" onclick="return false;"></div></li>
            <li><input type="submit" class="button" value="Create template"></li>
        </ul>
    </div>
</form>

當前的JS:

$("#preview").click(function() {
    $.post('preview.php', {body:$('#t-html').val().replace(/\n/g,'<br />'), function (result) {
        //maybe use .ajax instead? 
        //open preview.php in new window
    });
});

我如何使用相同的表格,但是根據一個人按下的按鈕有兩個不同的動作?

Preview template => preview.php => opens to a new tab

posts on same page Create template => save.php => posts on same page

您可以為按鈕同時具有click事件處理程序,並且可以同時附加ajax調用。

您可以使用javascript在新標簽頁中打開窗口。

window.open(<url>)

嘗試根據單擊的按鈕設置表單的“目標”屬性。

將您的窗體更改為以下內容:

<form id="create-template" class="form" action="" method="post" target="_blank">
    <p class="_50">
        <label for="t-name">Template name</label>
        <input type="text" name="t-name" class="required"/>
    </p>
    <p class="_100">
        <label for="t-html">Template HTML</label>
        <textarea id="t-html" name="t-html" class="required" rows="10" cols="40"></textarea>
    </p>
    <div class="clear"></div>

    <div class="block-actions">
        <ul class="actions-left">
            <li><a class="button red" id="reset-template" href="javascript:void(0);">Clear</a></li>
        </ul>
        <ul class="actions-right">
            <li><input id="preview-form" type="submit" class="button" value="Preview template" /></li>
            <li><input type="submit" id="submit-form" class="button" value="Create template" /></li>
        </ul>
    </div>
</form>​

並添加以下JavaScript:

$('#preview-form').click(function(ev) {
    $('#create-template').attr('action', 'preview.php');    
    $('#create-template').attr('target', '_blank');
});

$('#submit-form').click(function(ev) {
    $('#create-template').attr('action', 'submit.php');
    $('#create-template').attr('target', '');
});
​

我尚未在所有瀏覽器上都對此進行過測試,因此您可能需要這樣做。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM