Data text twitter javascript

Introduction

Twitter is a popular social media platform where users can share their views, and ideas and read posts from other users on a variety of topics. Researchers, developers, bloggers and people from many fields use Twitter for data gathering. You can find a well-written blog on how to create a developer’s account for the Twitter API. In this blog, all the parameters and filters are mentioned that one can use with the Standard Search API. It is highly suggested to go through that blog and get a basic idea about Twitter Search API. You can find the official documentation of API here. We will look at how to use the Twitter API in conjunction with JavaScript in this blog post. Instead of using any package wrapped around Twitter API, we will use the core Fetch library to get desired data from Twitter. We are not using any module that is wrapped around Twitter API, such as twitter-v2 and twitter-lite. The purpose is to make you understand how to use core Twitter API using the Fetch library.

Prerequisites

To get and install the node on your system, go to nodejs.dev and download the LTS(Long-term Support) version. After installation, open the terminal on your system and try the following commands and, you will see version numbers.

Extract Data using Fetch

In this section, we will see how to extract data from Twitter using the Fetch module. Fetch is a promise-based function used for sending and receiving data from the server. For this blog, we will focus only on getting data using Fetch.

Читайте также:  Css media min height

JavaScript that we use in the browsers (Vanilla JavaScript) has a Fetch module in it. Here, we are using node which is a JavaScript Runtime Environment through which we can run JavaScript on our local machine. This runtime environment does not have Fetch in its core modules. Therefore, we need to install it externally for our projects.

Before installing node-fetch, go to any directory/folder you desire to work in and create a folder with the name of your choice. Now, to install Fetch, open the terminal in the folder you created on your system and write as follows:

There are two ways to handle the fetch() method:

Using then() and catch()

The fetch method returns a response object that contains a range of useful promise-based methods. Those methods are as follows:

  • response.json() returns a promise resolved to a JSON object.
  • response.text() returns a promise resolved to raw text.
  • response.formData() returns a promise resolved to FormData.
  • response.blob() returns a promise resolved to a Blob (a file-like object of raw data).
  • response.arrayBuffer()() returns a promise resolved to an ArryBuffer (raw generic binary data).

As the Twitter API returns JSON data, we will only use the response.json() method. The following code is an example to fetch all tweets that contain the python keyword and does not contain any retweets:

const fetch = require('node-fetch') const token = 'Bearer BEARER_TOKEN' // Replace BEARER_TOKEN with your token const method = 'GET' const options =  method: method, headers:  'Content-type': 'application/json', Authorization: token, >, > const query = 'python -filter:retweets' const a = fetch(`https://api.twitter.com/1.1/search/tweets.json?q=$query>`, options) .then((response) => response.json()) .then((json) => console.log(json)) .catch((error) =>  console.log(error) >) 

Note: Replace the BEARER_TOKEN word with your Bearer Token that you got from the developers portal.

We can assign any search string and filter to the query. As shown in the code block, we used response.json() to get data in JSON format. Instead of a response, we can use any name that we pass as an argument in the first then() block. As mentioned earlier that response.json() again returns a promise. So, to resolve this promise, we used one more then() block and got the final response as data. In the process of resolving promises, if we get any error, then control will be passed to the catch() block. This block is used for handling any kind of error.

Using async/await

To use async/await, we need to create an async function and put our logic in that function. The following code shows how we can use the async/await with the fetch() method.

const fetch = require('node-fetch') const token = 'Bearer BEARER_TOKEN' // Replace BEARER_TOKEN with your token const method = 'GET' const options =  method: method, headers:  'Content-type': 'application/json', Authorization: token, >, > const query = 'python -filter:retweets' const getData = async () =>  try  const response = await fetch( `https://api.twitter.com/1.1/search/tweets.json?q=$query>`, options ) const data = await response.json() console.log(data) > catch (error)  console.log('ERROR') > > getData() 

As shown in the code, await will resolve promises and return the response. Here, we have used two awaits as fetch() method and response.json() both return promises.

Note: I have used the arrow function which is the syntax of JavaScript version ES6.

For the common data retrieval tasks, the above code is sufficient. You can use any query parameters and filters as per need and then assign them to the query. If you have used any different methods or filters, please share your expertise/methodology.

Conclusion

We can use any of the methods suitable to them. There can be other ways to get data. I have only mentioned one of them here. Many people prefer to use Axios which can be used in the same way as we used the fetch() method to get data using Twitter API. If you want to know about API, you can understand it easily through the «What is API?» blog.

Источник

Установить содержимое кнопки «Tweet» «data-text» динамически с помощью JavaScript или.

Вот функциональный код в форме, отображающей кнопку Tweet — кнопки в форме, отображающей несколько изображений, — когда пользователь нажимает одно из изображений, оно становится «выбранным» изображением, а кнопка Tweet должна твитнуть имя и URL выбранного изображения:

 Tweet  

У меня есть обработчик onclick() для div, который отображает изображение. Когда пользователь щелкает одно из изображений, вызывается его обработчик onclick() его div и устанавливает это изображение как «currentSelectedImage» на странице, а затем обработчику onclick() необходимо обновить «data-text» кнопки Tweet Атрибут с именем только что выбранного изображения:

 // This is part of the code of the 'onclick()' handler for // the image being selected.  

Мне нужно динамически изменить значение атрибута «data-text» в кнопке Tweet, чтобы оно стало именем выбранного изображения. Я добавил приведенный выше код javascript, который завершается ошибкой — ‘elem’, полученный из кода здесь:

 var elem = document.getElementById("tweetBtnId"); 

является нулевым (я думаю) из-за этой строки в коде кнопки твита Twitter:

Я не уверен, но похоже, что скрипт по умолчанию для кнопки Twitter Tweet перезаписывает любые попытки добавить атрибут ‘id’ к кнопке Tweet.

Вы увидите, что я добавил id=»tweetBtnId» к кнопке Tweet выше, чтобы я мог получить доступ к кнопке Tweet в моем обработчике выбора изображения onclick() выше, а затем присвоил «data-text» имя только что выбранное изображение.

Я просто сомневаюсь, что цель разработки Twitter для кнопки Tweet заключалась в следующем: «мы будем тупить этот присосок ПУТЬ, мы только позволим этим животным выбрать ОДНО значение текст-данные — каждая кнопка Tweet должна иметь одну жестко закодированную» -on-the-page «атрибут data-text — шутить над ними, если они пытаются динамически изменить атрибут data-text кнопки Tweet.»

Мне нужно заставить это работать — есть идеи?

Источник

Оцените статью