如何用按钮替换html href链接

时间:2014-04-07 12:39:39

标签: javascript html button href

我有一个包含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); };
});

3 个答案:

答案 0 :(得分:1)

如果您希望链接看起来像一个按钮,那么您可以使用css设置样式,使其看起来像一个按钮。

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

答案 1 :(得分:0)

现在就按照自己的方式设计吧!=)

(IE优化:) 不确定这是否正确。

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

普通按钮

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

表单方法:

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

答案 2 :(得分:-2)

<击>

<击>

Dude首先将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()不安全: Is it safe to call $(document).ready() from inside a function?

编辑:伙计你是对的,我真的很抱歉,在回答之前我没有看到整个问题。

user1062153无需在javascript中执行额外的工作,您只需将id提供给您正在使用的元素即可。只需添加

即可
<button id="hour">Hour</button>
正如Xatenev所说。这应该工作正常..