簡體   English   中英

如何用按鈕替換html href鏈接

[英]How to replace html href link with button

我有一個包含 Javascript 的 HTML 頁面(見下文)。

在 HTML 頁面中有一個調用 Javascript 函數的 HTML 代碼行。 這完全按照它應該的方式工作,看起來像這樣:

<a href="#" id="hour">hour</a> 

此代碼行從以下 Javascript 的最后一部分調用。

我想用一個按鈕替換這個代碼行。 我怎樣才能做到這一點 ?

謝謝

ps Javascript 是與 dygraph 一起使用的,我沒有寫它。 我對 Javascript 知之甚少。 我只是想用一個按鈕替換上面的單行 html,該按鈕執行相同的工作或通過其他簡約更改生成一個按鈕。

$(document).ready(function () {
    var r = [ ];
    var base_time = Date.parse("2014/03/05");
    var num = 24 * 0.25 * 365;

    for (var i = 0; i < num; i++) {
        r.push([
            new Date(base_time + i * 3600 * 1000),
            i + 50 * (i % 60),        // line
            i * (num - i) * 4.0 / num  // parabola
        ]);
    }

    var orig_range = [
        r[0][0].valueOf(),
        r[r.length - 1][0].valueOf()
    ];

    // NEW CODE INSERTED -   STARTS
    var one_month_previous = new Date();
    one_month_previous.setMonth(one_month_previous.getMonth() - 1);

    var one_week_previous = new Date();
    one_week_previous.setDate(one_week_previous.getDate()-7);

    var three_days_previous = new Date();
    three_days_previous.setDate(three_days_previous.getDate()-3);

    var one_days_previous = new Date();
    one_days_previous.setDate(one_days_previous.getDate()-1);

    var twelve_hours_previous = new Date();
    twelve_hours_previous.setHours(twelve_hours_previous.getHours() - 12);


    // NEW CODE INSERTED -   ENDS

    g = new Dygraph(
        document.getElementById("graphdiv3"),
        "show_csv.php",
        {

            // NEW CODE INSERTED -   STARTS
            //  dateWindow: [ Date.parse(one_month_previous) ,
            //            Date.parse(new Date()) ],

            dateWindow: [
                    Date.parse(one_week_previous),
                    Date.parse(new Date())
            ],

            //  dateWindow: [ Date.parse(three_days_previous) ,
            //            Date.parse(new Date()) ],

            //  dateWindow: [ Date.parse(one_days_previous) ,
            //            Date.parse(new Date()) ],

            //  dateWindow: [ Date.parse(twelve_hours_previous) ,
            //            Date.parse(new Date()) ],

            //  dateWindow: [ Date.parse("2014/03/01 12:00:00"),    
            //            Date.parse("2014/03/31 12:00:00") ],   

            // NEW CODE INSERTED -   ENDS

            title: 'Temperature(&deg;C) vs Time',
            rollPeriod: 1,
            showRoller: true,
            xlabel: 'Time',
            ylabel: 'Temperature (&deg;C)',
            legend: 'always',
            labelsKMB: 'true',
            labelsSeparateLines: 'true',
            colors: [
                "rgb(51,204,204)",
                "#00DD55",
                "rgb(255,100,100)",
                "rgba(50,50,200,0.4)"
            ]
        }
    );


    var desired_range = null;

    function approach_range() {
        if (!desired_range) return;
        // go halfway there
        var range = g.xAxisRange();

        if (Math.abs(desired_range[0] - range[0]) < 60 &&
            Math.abs(desired_range[1] - range[1]) < 60) {
                g.updateOptions({dateWindow: desired_range});
                // (do not set another timeout.)
        } else {
            var new_range;
            new_range = [
                0.5 * (desired_range[0] + range[0]),
                0.5 * (desired_range[1] + range[1])
            ];
            g.updateOptions({dateWindow: new_range});
            animate();
        }
    }

    function animate() {
        setTimeout(approach_range, 50);
    }

    var zoom = function(res) {
        var w = g.xAxisRange();
        desired_range = [ w[0], w[0] + res * 1000 ];
        animate();
    }

    var reset = function() {
        desired_range = orig_range;
        animate();
    }

    var pan = function(dir) {
        var w = g.xAxisRange();
        var scale = w[1] - w[0];
        var amount = scale * 0.25 * dir;
        desired_range = [
            w[0] + amount,
            w[1] + amount
        ];
        animate();
    }

    document.getElementById('hour').onclick = function() { zoom(3600); };
    document.getElementById('day').onclick = function() { zoom(86400); };
    document.getElementById('week').onclick = function() { zoom(604800); };
    document.getElementById('month').onclick = function() { zoom(30 * 86400); };
    document.getElementById('full').onclick = function() { reset(); };
    document.getElementById('left').onclick = function() { pan(-1); };
    document.getElementById('right').onclick = function() { pan(+1); };
});

如果您希望鏈接看起來像一個按鈕,那么您可以使用 css 將鏈接的樣式設置為看起來像一個按鈕。

http://www.usabilitypost.com/2012/01/10/pressed-button-state-with-css3/

現在就按照自己的方式設計吧!=)

(IE 優化:)不確定這是否正確。

<a href="#">
    <button id="hour">Hour</button>
</a>

普通按鈕

<button id="hour">Hour</button>

表格方法:

<form action="#">
    <input type="submit" value="submit">
</form>

哥們先把javascript封裝在一個函數里面 //

 
 
  
   function foo() { $(document).ready(function () { var r = [ ]; var base_time = Date.parse("2014/03/05"); var num = 24 * 0.25 * 365; for (var i = 0; i < num; i++) { r.push([ new Date(base_time + i * 3600 * 1000), i + 50 * (i % 60), // line i * (num - i) * 4.0 / num // parabola ]); } var orig_range = [ r[0][0].valueOf(), r[r.length - 1][0].valueOf() ]; // NEW CODE INSERTED - STARTS var one_month_previous = new Date(); one_month_previous.setMonth(one_month_previous.getMonth() - 1); var one_week_previous = new Date(); one_week_previous.setDate(one_week_previous.getDate()-7); var three_days_previous = new Date(); three_days_previous.setDate(three_days_previous.getDate()-3); var one_days_previous = new Date(); one_days_previous.setDate(one_days_previous.getDate()-1); var twelve_hours_previous = new Date(); twelve_hours_previous.setHours(twelve_hours_previous.getHours() - 12); // NEW CODE INSERTED - ENDS g = new Dygraph( document.getElementById("graphdiv3"), "show_csv.php", { // NEW CODE INSERTED - STARTS // dateWindow: [ Date.parse(one_month_previous) , // Date.parse(new Date()) ], dateWindow: [ Date.parse(one_week_previous) , Date.parse(new Date()) ], // dateWindow: [ Date.parse(three_days_previous) , // Date.parse(new Date()) ], // dateWindow: [ Date.parse(one_days_previous) , // Date.parse(new Date()) ], // dateWindow: [ Date.parse(twelve_hours_previous) , // Date.parse(new Date()) ], // dateWindow: [ Date.parse("2014/03/01 12:00:00"), // Date.parse("2014/03/31 12:00:00") ], // NEW CODE INSERTED - ENDS title: 'Temperature(&deg;C) vs Time', rollPeriod: 1, showRoller: true, xlabel: 'Time', ylabel: 'Temperature (&deg;C)', legend: 'always', labelsKMB: 'true', labelsSeparateLines: 'true', colors: [ "rgb(51,204,204)", "#00DD55", "rgb(255,100,100)", "rgba(50,50,200,0.4)"] } ); var desired_range = null; function approach_range() { if (!desired_range) return; // go halfway there var range = g.xAxisRange(); if (Math.abs(desired_range[0] - range[0]) < 60 && Math.abs(desired_range[1] - range[1]) < 60) { g.updateOptions({dateWindow: desired_range}); // (do not set another timeout.) } else { var new_range; new_range = [0.5 * (desired_range[0] + range[0]), 0.5 * (desired_range[1] + range[1])]; g.updateOptions({dateWindow: new_range}); animate(); } } function animate() { setTimeout(approach_range, 50); } var zoom = function(res) { var w = g.xAxisRange(); desired_range = [ w[0], w[0] + res * 1000 ]; animate(); } var reset = function() { desired_range = orig_range; animate(); } var pan = function(dir) { var w = g.xAxisRange(); var scale = w[1] - w[0]; var amount = scale * 0.25 * dir; desired_range = [ w[0] + amount, w[1] + amount ]; animate(); } document.getElementById('hour').onclick = function() { zoom(3600); }; document.getElementById('day').onclick = function() { zoom(86400); }; document.getElementById('week').onclick = function() { zoom(604800); }; document.getElementById('month').onclick = function() { zoom(30 * 86400); }; document.getElementById('full').onclick = function() { reset(); }; document.getElementById('left').onclick = function() { pan(-1); }; document.getElementById('right').onclick = function() { pan(+1); }; } ); } //]]> </script>
 
 

現在,從按鈕調用函數

 
 
  
  <button id="hour" onClick="foo()">Hour</button>
 
 

編輯:對於 document.ready() 不安全: 從函數內部調用 $(document).ready() 是否安全?

編輯:伙計們,你們是對的,我真的很抱歉,我在回答之前沒有看到整個問題。

user1062153 不需要在 javascript 中做額外的工作,你只需要給你正在使用的元素提供 id。 只需添加

<button id="hour">Hour</button>

正如哈特涅夫所說。 那應該可以正常工作..

暫無
暫無

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

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