从<p>标记到twitter小部件文本数据属性

Pass data from generated value of <p> tag to twitter widget text-data attribute

本文关键字:小部 twitter 文本 数据属性 lt gt      更新时间:2023-09-26

我正在尝试将数据从我的p标记传递到新tweet中的data-text属性。问题是,标签中显示的数据是从数组中生成的,我的twitter小部件不识别动态值。

这是JS Fiddle

<!--   <div id="DIV1">This is the first quote</div>   -->
<p id="DIV1"></p>
<script>
    var arr = ["This is first quote", 
              "This is second quote", 
              "This is third quote", 
              "This is fourth quote", 
              "This is fifth quote"];
    function choseRandQuote() {
        var  randomQuote = Math.floor(Math.random()*(arr.length)); 
        document.getElementById('DIV1').innerHTML = arr[randomQuote];
    } 
</script>
<div class="button-place"> <!-- /reserved exclusevly for button-->
    <button id="btn-gnr" class="btn" onclick="choseRandQuote();">Generate!</button>
</div><!-- /end .button -->
<br />
<br />
<div id="twtbtn"></div>
<!-- and-->
<script>
    var MyDiv1 = document.getElementById('DIV1').innerHTML;
    window.twttr = (function(d, s, id) {
        var t, js, fjs = d.getElementsByTagName(s)[0];
        if (d.getElementById(id)) return;
        js = d.createElement(s);
        js.id = id;
        js.src = "https://platform.twitter.com/widgets.js";
        fjs.parentNode.insertBefore(js, fjs);
        return window.twttr || (t = {
            _e: [],
            ready: function(f) {
                t._e.push(f)
            }
        });
    }(document, "script", "twitter-wjs"));
    twttr.ready(function(twttr) {
        twttr.widgets.createShareButton(
            'http://twitter.com',
            document.getElementById('twtbtn'),
            function(el) {
                console.log("Button created.")
            }, 
            {
                count: 'none',
                text: "Quote: " + MyDiv1,
                via: 'alex_ryzhuk',
                hashtags: 'FreeCodeCamp'
            }
        );
        twttr.events.bind('tweet', function(event) {
            console.log(event, event.target);
        });
    });
</script>

您的tweet按钮在dom加载时呈现,因此您的div为空。每次更改报价时,您都需要重新生成推特按钮。

<!--   <div id="DIV1">This is the first quote</div>   -->
<p id="DIV1"></p>
  <script>
var arr = ["This is first quote", 
			  "This is second quote", 
			  "This is third quote", 
			  "This is fourth quote", 
			  "This is fifth quote"];
 
function choseRandQuote() {
	var  randomQuote = Math.floor(Math.random()*(arr.length)); 
	document.getElementById('DIV1').innerHTML = arr[randomQuote];
   addTwitter();
	} 
        </script>
<div class="button-place"> <!-- /reserved exclusevly for button-->
                <button id="btn-gnr"
                        class="btn"
                        onclick="choseRandQuote();"> 
                    Generate! 
                </button>
                </div><!-- /end .button -->
<br />
<br />
<div id="twtbtn"></div>
<script>
  
function addTwitter(){
var MyDiv1 = document.getElementById('DIV1').innerHTML;
window.twttr = (function(d, s, id) {
  var t, js, fjs = d.getElementsByTagName(s)[0];
  if (d.getElementById(id)) return;
  js = d.createElement(s);
  js.id = id;
  js.src = "https://platform.twitter.com/widgets.js";
  fjs.parentNode.insertBefore(js, fjs);
  return window.twttr || (t = {
    _e: [],
    ready: function(f) {
      t._e.push(f)
    }
  });
}(document, "script", "twitter-wjs"));
twttr.ready(function(twttr) {
  twttr.widgets.createShareButton(
    'http://twitter.com',
    document.getElementById('twtbtn'),
    function(el) {
      console.log("Button created.")
    }, {
      count: 'none',
      text: "Quote: " + MyDiv1,
      via: 'alex_ryzhuk',
      hashtags: 'FreeCodeCamp'
    }
  );
  twttr.events.bind('tweet', function(event) {
    console.log(event, event.target);
  });
});
}
addTwitter();
</script>

Jquery方法:
$(".btn-tweet").click(function () {
        var width  = 575,
        height = 400,
        left   = ($(window).width()  - width)  / 2,
        top    = ($(window).height() - height) / 2,
        url    = 'http://twitter.com/share?text=' + $info.quote + " - " + $info.author,
        opts   = 'status=1' +
                 ',width='  + width  +
                 ',height=' + height +
                 ',top='    + top    +
                 ',left='   + left;
        window.open(url, 'twitter', opts);
    });

示例