如何在JavaScript中捕获属性的值而不是jQuery

时间:2017-02-22 13:26:18

标签: javascript getattribute bootstrap-slider

我想使用JavaScript捕获标记上的属性值。我还没有成功。

这是我的HTML标记:

<html>
<head>
...
  <!-- bootstrap-slider Plugin -->
  <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-slider/9.7.2/bootstrap-slider.min.js"></script>
  <link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-slider/9.7.2/css/bootstrap-slider.min.css" rel="stylesheet">    
...
</head>
<body>
...
    <div class="form-group">
      <label class="col-md-4 control-label" for="language_spanish">Spanish</label>
      <div class="col-md-6">
        <input id="language_spanish" type="text" data-provide="slider"
          data-slider-ticks="[0,1,2]"
          data-slider-min="0"
          data-slider-max="2"
          data-slider-step="1"
          data-slider-value="0"
          data-slider-tooltip="show"
          data-identifier="this is what I want to capture"
        />
      </div>
    </div>
...
</body>
</html>

这是我的javascript:

var spanish = new Slider( '#language_spanish', { formatter } );
spanish.on( 'slideStop', function( value ) {
  alert( value ); // this works perfectly!
  alert( this.getAttribute( 'data-identifier' ) ); // does not work
  alert( spanish.getAttribute( 'data-identifier' ) ); // does not work either
  alert( spanish.attr( 'data-identifier' ) ); // does not work as well
});

有可能吗?

FYI jQuery不能与bootstrap-slider一起使用。经过尝试和尝试,我一直在打砖墙。 JavaScript是我使用此插件检索值和属性的唯一方法。

修改后包含插件来源:

https://cdnjs.cloudflare.com/ajax/libs/bootstrap-slider/9.7.2/bootstrap-slider.min.js

https://cdnjs.cloudflare.com/ajax/libs/bootstrap-slider/9.7.2/css/bootstrap-slider.min.css

2 个答案:

答案 0 :(得分:3)

您可以使用spanish.element对象返回底层DOM元素的引用,然后可以使用getAttribute()方法。

&#13;
&#13;
var spanish = new Slider('#language_spanish');
console.log(spanish.element.getAttribute( 'data-identifier'))
&#13;
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-slider/9.7.2/css/bootstrap-slider.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-slider/9.7.2/bootstrap-slider.js"></script>


<div class="form-group">
  <label class="col-md-4 control-label" for="language_spanish">Spanish</label>
  <div class="col-md-6">
    <input id="language_spanish" type="text" data-provide="slider" data-slider-ticks="[0,1,2]" data-slider-min="0" data-slider-max="2" data-slider-step="1" data-slider-value="0" data-slider-tooltip="show" data-identifier="this is what I want to capture" />
  </div>
</div>
&#13;
&#13;
&#13;

答案 1 :(得分:0)

您尝试访问spanish上的属性,该属性是Slider对象,而不是DOM对象。滑块对象没有getAttribute方法。我建议您查看Slider插件文档,看看是否有一种方法可以检索DOM对象的参数,或者另外跟踪DOM元素。

如果在DOM对象上使用getAttribute方法,它将正常工作:

this.getAttribute( 'data-identifier' )