How to copy text, which is in a for-each loop, to clipboard when button is clicked?











up vote
0
down vote

favorite
2












I have a for-each loop which prints out some text from a database and also displays a button. So essentially I have multiple "areas" of text and each with their own button. I want it so that whenever a user clicks on a button, that specific text it is matched up with is copied to the clipboard.



I tried doing multiple searches on this before posting on here. However, from the other solutions, I read they more or less show a solution for copying text in an input tag. However, in my case the user is not typing anything in that needs to get copied - the text is already on the screen and can't be changed.



I am having trouble with copying that specific text that matches a button since the text does not have a specific id or class name because it is just printing text as it goes through the loop, so they all have the same class name. So how would I specify a specific text with that button, since the buttons could get pressed in any order?



HTML:



<c:forEach items="${items}" var="item">
<h2>${item.itemDescription}</h2>
<input class="big-button" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
</c:forEach>


JavaScript:



function status(clickedBtn) 
{
clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';
}









share|improve this question




















  • 2




    I've used this answer to get text onto the clipboard: stackoverflow.com/a/33928558/74757. You could use a selector to get the text from the <h2> item and pass that.
    – Cᴏʀʏ
    Nov 11 at 22:07








  • 1




    You could use the index of the item in the loop to generate an id too, so you can reference your element easier.
    – Cᴏʀʏ
    Nov 11 at 22:13










  • @Cᴏʀʏ, thanks so much for linking that. So, I checked it out and it seems like they are able to do new Date() which copies the date to the clipboard. However, in my case, I have to copy the string that is is in the loop -- ${item.itemDescription}. So, how would I be able to call that, since that is in my HTML, and not in the JS.
    – daisygal
    Nov 11 at 22:14










  • @Cᴏʀʏ oh okay that makes sense. Sorry, I am still new to HTML and JS. how would I be able to reference a certain index, since I theoretically don't know how many elements there are since I am getting the information from the database and inserting into my HTML.
    – daisygal
    Nov 11 at 22:15












  • What templating framework are you using?
    – Cᴏʀʏ
    Nov 11 at 22:15















up vote
0
down vote

favorite
2












I have a for-each loop which prints out some text from a database and also displays a button. So essentially I have multiple "areas" of text and each with their own button. I want it so that whenever a user clicks on a button, that specific text it is matched up with is copied to the clipboard.



I tried doing multiple searches on this before posting on here. However, from the other solutions, I read they more or less show a solution for copying text in an input tag. However, in my case the user is not typing anything in that needs to get copied - the text is already on the screen and can't be changed.



I am having trouble with copying that specific text that matches a button since the text does not have a specific id or class name because it is just printing text as it goes through the loop, so they all have the same class name. So how would I specify a specific text with that button, since the buttons could get pressed in any order?



HTML:



<c:forEach items="${items}" var="item">
<h2>${item.itemDescription}</h2>
<input class="big-button" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
</c:forEach>


JavaScript:



function status(clickedBtn) 
{
clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';
}









share|improve this question




















  • 2




    I've used this answer to get text onto the clipboard: stackoverflow.com/a/33928558/74757. You could use a selector to get the text from the <h2> item and pass that.
    – Cᴏʀʏ
    Nov 11 at 22:07








  • 1




    You could use the index of the item in the loop to generate an id too, so you can reference your element easier.
    – Cᴏʀʏ
    Nov 11 at 22:13










  • @Cᴏʀʏ, thanks so much for linking that. So, I checked it out and it seems like they are able to do new Date() which copies the date to the clipboard. However, in my case, I have to copy the string that is is in the loop -- ${item.itemDescription}. So, how would I be able to call that, since that is in my HTML, and not in the JS.
    – daisygal
    Nov 11 at 22:14










  • @Cᴏʀʏ oh okay that makes sense. Sorry, I am still new to HTML and JS. how would I be able to reference a certain index, since I theoretically don't know how many elements there are since I am getting the information from the database and inserting into my HTML.
    – daisygal
    Nov 11 at 22:15












  • What templating framework are you using?
    – Cᴏʀʏ
    Nov 11 at 22:15













up vote
0
down vote

favorite
2









up vote
0
down vote

favorite
2






2





I have a for-each loop which prints out some text from a database and also displays a button. So essentially I have multiple "areas" of text and each with their own button. I want it so that whenever a user clicks on a button, that specific text it is matched up with is copied to the clipboard.



I tried doing multiple searches on this before posting on here. However, from the other solutions, I read they more or less show a solution for copying text in an input tag. However, in my case the user is not typing anything in that needs to get copied - the text is already on the screen and can't be changed.



I am having trouble with copying that specific text that matches a button since the text does not have a specific id or class name because it is just printing text as it goes through the loop, so they all have the same class name. So how would I specify a specific text with that button, since the buttons could get pressed in any order?



HTML:



<c:forEach items="${items}" var="item">
<h2>${item.itemDescription}</h2>
<input class="big-button" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
</c:forEach>


JavaScript:



function status(clickedBtn) 
{
clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';
}









share|improve this question















I have a for-each loop which prints out some text from a database and also displays a button. So essentially I have multiple "areas" of text and each with their own button. I want it so that whenever a user clicks on a button, that specific text it is matched up with is copied to the clipboard.



I tried doing multiple searches on this before posting on here. However, from the other solutions, I read they more or less show a solution for copying text in an input tag. However, in my case the user is not typing anything in that needs to get copied - the text is already on the screen and can't be changed.



I am having trouble with copying that specific text that matches a button since the text does not have a specific id or class name because it is just printing text as it goes through the loop, so they all have the same class name. So how would I specify a specific text with that button, since the buttons could get pressed in any order?



HTML:



<c:forEach items="${items}" var="item">
<h2>${item.itemDescription}</h2>
<input class="big-button" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
</c:forEach>


JavaScript:



function status(clickedBtn) 
{
clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';
}






javascript html






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 12 at 0:20









Poul Bak

5,43331132




5,43331132










asked Nov 11 at 22:03









daisygal

133




133








  • 2




    I've used this answer to get text onto the clipboard: stackoverflow.com/a/33928558/74757. You could use a selector to get the text from the <h2> item and pass that.
    – Cᴏʀʏ
    Nov 11 at 22:07








  • 1




    You could use the index of the item in the loop to generate an id too, so you can reference your element easier.
    – Cᴏʀʏ
    Nov 11 at 22:13










  • @Cᴏʀʏ, thanks so much for linking that. So, I checked it out and it seems like they are able to do new Date() which copies the date to the clipboard. However, in my case, I have to copy the string that is is in the loop -- ${item.itemDescription}. So, how would I be able to call that, since that is in my HTML, and not in the JS.
    – daisygal
    Nov 11 at 22:14










  • @Cᴏʀʏ oh okay that makes sense. Sorry, I am still new to HTML and JS. how would I be able to reference a certain index, since I theoretically don't know how many elements there are since I am getting the information from the database and inserting into my HTML.
    – daisygal
    Nov 11 at 22:15












  • What templating framework are you using?
    – Cᴏʀʏ
    Nov 11 at 22:15














  • 2




    I've used this answer to get text onto the clipboard: stackoverflow.com/a/33928558/74757. You could use a selector to get the text from the <h2> item and pass that.
    – Cᴏʀʏ
    Nov 11 at 22:07








  • 1




    You could use the index of the item in the loop to generate an id too, so you can reference your element easier.
    – Cᴏʀʏ
    Nov 11 at 22:13










  • @Cᴏʀʏ, thanks so much for linking that. So, I checked it out and it seems like they are able to do new Date() which copies the date to the clipboard. However, in my case, I have to copy the string that is is in the loop -- ${item.itemDescription}. So, how would I be able to call that, since that is in my HTML, and not in the JS.
    – daisygal
    Nov 11 at 22:14










  • @Cᴏʀʏ oh okay that makes sense. Sorry, I am still new to HTML and JS. how would I be able to reference a certain index, since I theoretically don't know how many elements there are since I am getting the information from the database and inserting into my HTML.
    – daisygal
    Nov 11 at 22:15












  • What templating framework are you using?
    – Cᴏʀʏ
    Nov 11 at 22:15








2




2




I've used this answer to get text onto the clipboard: stackoverflow.com/a/33928558/74757. You could use a selector to get the text from the <h2> item and pass that.
– Cᴏʀʏ
Nov 11 at 22:07






I've used this answer to get text onto the clipboard: stackoverflow.com/a/33928558/74757. You could use a selector to get the text from the <h2> item and pass that.
– Cᴏʀʏ
Nov 11 at 22:07






1




1




You could use the index of the item in the loop to generate an id too, so you can reference your element easier.
– Cᴏʀʏ
Nov 11 at 22:13




You could use the index of the item in the loop to generate an id too, so you can reference your element easier.
– Cᴏʀʏ
Nov 11 at 22:13












@Cᴏʀʏ, thanks so much for linking that. So, I checked it out and it seems like they are able to do new Date() which copies the date to the clipboard. However, in my case, I have to copy the string that is is in the loop -- ${item.itemDescription}. So, how would I be able to call that, since that is in my HTML, and not in the JS.
– daisygal
Nov 11 at 22:14




@Cᴏʀʏ, thanks so much for linking that. So, I checked it out and it seems like they are able to do new Date() which copies the date to the clipboard. However, in my case, I have to copy the string that is is in the loop -- ${item.itemDescription}. So, how would I be able to call that, since that is in my HTML, and not in the JS.
– daisygal
Nov 11 at 22:14












@Cᴏʀʏ oh okay that makes sense. Sorry, I am still new to HTML and JS. how would I be able to reference a certain index, since I theoretically don't know how many elements there are since I am getting the information from the database and inserting into my HTML.
– daisygal
Nov 11 at 22:15






@Cᴏʀʏ oh okay that makes sense. Sorry, I am still new to HTML and JS. how would I be able to reference a certain index, since I theoretically don't know how many elements there are since I am getting the information from the database and inserting into my HTML.
– daisygal
Nov 11 at 22:15














What templating framework are you using?
– Cᴏʀʏ
Nov 11 at 22:15




What templating framework are you using?
– Cᴏʀʏ
Nov 11 at 22:15












3 Answers
3






active

oldest

votes

















up vote
2
down vote



accepted










I would change your HTML to generate some kind of ID that can be used to reference the element with your text.



<c:forEach items="${items}" var="item" varStatus="loop">
<h2 id="item-desc-${loop.index}">${item.itemDescription}</h2>
<input class="big-button" data-desc-ref="item-desc-${loop.index}" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
</c:forEach>


Above I added code to generate a unique id (e.g. id="item-desc-0") on each <h2> element. On the button, I added a data- attribute to reference the ID of the <h2> so we can retrieve it later.



Now we change your status function to find the element by the ID specified in the data attribute, and get its innerText (the content between the opening and closing tags).



Then, you can pass that text to the function that copies it to the clipboard, reference above in my comment.



  function status(clickedBtn) 
{
var text = document.getElementById(clickedBtn.dataset.descRef).innerText;
copyToClipboard(text);

clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';
}


Here's a working example. I had to put in sample HTML that would be generated by your loop.






function copyToClipboard(text) {
if (window.clipboardData && window.clipboardData.setData) {
// IE specific code path to prevent textarea being shown while dialog is visible.
return clipboardData.setData("Text", text);

} else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
var textarea = document.createElement("textarea");
textarea.textContent = text;
textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
document.body.appendChild(textarea);
textarea.select();
try {
return document.execCommand("copy"); // Security exception may be thrown by some browsers.
} catch (ex) {
console.warn("Copy to clipboard failed.", ex);
return false;
} finally {
document.body.removeChild(textarea);
}
}
}

function status(clickedBtn) {
var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

copyToClipboard(text);

clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';
}

<h2 id="item-desc-0">Testing 0</h2>
<input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

<h2 id="item-desc-1">Testing 1</h2>
<input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

<h2 id="item-desc-2">Testing 2</h2>
<input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">








share|improve this answer























  • @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
    – daisygal
    Nov 11 at 23:12












  • I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
    – Cᴏʀʏ
    Nov 12 at 20:10










  • @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
    – daisygal
    Nov 14 at 23:47










  • You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
    – Cᴏʀʏ
    Nov 15 at 1:32


















up vote
0
down vote













Cory provides a very helpful link to the clipboard aspect, I thought I'd provide the info about how to target a clicked element.



To achieve this, pass event to your onclick attribute, and use event.target to reference the clicked element. Here's a basic example:






function copy(e) {
alert(e.target.value)
}

<button onclick="copy(event)" value="copy this">copy this</button>
<button onclick="copy(event)" value="copy that">copy that</button>





To address your specific requirement, if you put item.itemDescription into the value attribute, then it will copy the text you want.






share|improve this answer





















  • thanks so much! So since I already have something in my value attribute, is there another way around this?
    – daisygal
    Nov 11 at 22:26










  • @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
    – Frish
    Nov 11 at 22:32




















up vote
0
down vote













If h2 element exactly is on previous of button you can use like this.






function status(clickedBtn) 
{
clickedBtn.value = "Copied to clipboard";
clickedBtn.disabled = true;
clickedBtn.style.color = 'white';
clickedBtn.style.background = 'gray';

//New Code
copyToCliboard(clickedBtn.previousSibling);
}
function copyToCliboard(el) {
if (document.body.createTextRange) {
var range = document.body.createTextRange();
range.moveToElementText(el);
range.select();
} else {
var selection = window.getSelection();
var range = document.createRange();
range.selectNodeContents(el);
selection.removeAllRanges();
selection.addRange(range);
}
document.execCommand("copy");
window.getSelection().removeAllRanges();
}

h2{
display:inline;
}

<html>
<head>
</head>
<body>
<div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
<div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
</body>
</html>








share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53253702%2fhow-to-copy-text-which-is-in-a-for-each-loop-to-clipboard-when-button-is-click%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    3 Answers
    3






    active

    oldest

    votes








    3 Answers
    3






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    2
    down vote



    accepted










    I would change your HTML to generate some kind of ID that can be used to reference the element with your text.



    <c:forEach items="${items}" var="item" varStatus="loop">
    <h2 id="item-desc-${loop.index}">${item.itemDescription}</h2>
    <input class="big-button" data-desc-ref="item-desc-${loop.index}" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
    </c:forEach>


    Above I added code to generate a unique id (e.g. id="item-desc-0") on each <h2> element. On the button, I added a data- attribute to reference the ID of the <h2> so we can retrieve it later.



    Now we change your status function to find the element by the ID specified in the data attribute, and get its innerText (the content between the opening and closing tags).



    Then, you can pass that text to the function that copies it to the clipboard, reference above in my comment.



      function status(clickedBtn) 
    {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;
    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }


    Here's a working example. I had to put in sample HTML that would be generated by your loop.






    function copyToClipboard(text) {
    if (window.clipboardData && window.clipboardData.setData) {
    // IE specific code path to prevent textarea being shown while dialog is visible.
    return clipboardData.setData("Text", text);

    } else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
    var textarea = document.createElement("textarea");
    textarea.textContent = text;
    textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
    document.body.appendChild(textarea);
    textarea.select();
    try {
    return document.execCommand("copy"); // Security exception may be thrown by some browsers.
    } catch (ex) {
    console.warn("Copy to clipboard failed.", ex);
    return false;
    } finally {
    document.body.removeChild(textarea);
    }
    }
    }

    function status(clickedBtn) {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }

    <h2 id="item-desc-0">Testing 0</h2>
    <input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-1">Testing 1</h2>
    <input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-2">Testing 2</h2>
    <input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">








    share|improve this answer























    • @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
      – daisygal
      Nov 11 at 23:12












    • I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
      – Cᴏʀʏ
      Nov 12 at 20:10










    • @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
      – daisygal
      Nov 14 at 23:47










    • You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
      – Cᴏʀʏ
      Nov 15 at 1:32















    up vote
    2
    down vote



    accepted










    I would change your HTML to generate some kind of ID that can be used to reference the element with your text.



    <c:forEach items="${items}" var="item" varStatus="loop">
    <h2 id="item-desc-${loop.index}">${item.itemDescription}</h2>
    <input class="big-button" data-desc-ref="item-desc-${loop.index}" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
    </c:forEach>


    Above I added code to generate a unique id (e.g. id="item-desc-0") on each <h2> element. On the button, I added a data- attribute to reference the ID of the <h2> so we can retrieve it later.



    Now we change your status function to find the element by the ID specified in the data attribute, and get its innerText (the content between the opening and closing tags).



    Then, you can pass that text to the function that copies it to the clipboard, reference above in my comment.



      function status(clickedBtn) 
    {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;
    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }


    Here's a working example. I had to put in sample HTML that would be generated by your loop.






    function copyToClipboard(text) {
    if (window.clipboardData && window.clipboardData.setData) {
    // IE specific code path to prevent textarea being shown while dialog is visible.
    return clipboardData.setData("Text", text);

    } else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
    var textarea = document.createElement("textarea");
    textarea.textContent = text;
    textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
    document.body.appendChild(textarea);
    textarea.select();
    try {
    return document.execCommand("copy"); // Security exception may be thrown by some browsers.
    } catch (ex) {
    console.warn("Copy to clipboard failed.", ex);
    return false;
    } finally {
    document.body.removeChild(textarea);
    }
    }
    }

    function status(clickedBtn) {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }

    <h2 id="item-desc-0">Testing 0</h2>
    <input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-1">Testing 1</h2>
    <input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-2">Testing 2</h2>
    <input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">








    share|improve this answer























    • @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
      – daisygal
      Nov 11 at 23:12












    • I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
      – Cᴏʀʏ
      Nov 12 at 20:10










    • @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
      – daisygal
      Nov 14 at 23:47










    • You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
      – Cᴏʀʏ
      Nov 15 at 1:32













    up vote
    2
    down vote



    accepted







    up vote
    2
    down vote



    accepted






    I would change your HTML to generate some kind of ID that can be used to reference the element with your text.



    <c:forEach items="${items}" var="item" varStatus="loop">
    <h2 id="item-desc-${loop.index}">${item.itemDescription}</h2>
    <input class="big-button" data-desc-ref="item-desc-${loop.index}" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
    </c:forEach>


    Above I added code to generate a unique id (e.g. id="item-desc-0") on each <h2> element. On the button, I added a data- attribute to reference the ID of the <h2> so we can retrieve it later.



    Now we change your status function to find the element by the ID specified in the data attribute, and get its innerText (the content between the opening and closing tags).



    Then, you can pass that text to the function that copies it to the clipboard, reference above in my comment.



      function status(clickedBtn) 
    {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;
    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }


    Here's a working example. I had to put in sample HTML that would be generated by your loop.






    function copyToClipboard(text) {
    if (window.clipboardData && window.clipboardData.setData) {
    // IE specific code path to prevent textarea being shown while dialog is visible.
    return clipboardData.setData("Text", text);

    } else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
    var textarea = document.createElement("textarea");
    textarea.textContent = text;
    textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
    document.body.appendChild(textarea);
    textarea.select();
    try {
    return document.execCommand("copy"); // Security exception may be thrown by some browsers.
    } catch (ex) {
    console.warn("Copy to clipboard failed.", ex);
    return false;
    } finally {
    document.body.removeChild(textarea);
    }
    }
    }

    function status(clickedBtn) {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }

    <h2 id="item-desc-0">Testing 0</h2>
    <input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-1">Testing 1</h2>
    <input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-2">Testing 2</h2>
    <input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">








    share|improve this answer














    I would change your HTML to generate some kind of ID that can be used to reference the element with your text.



    <c:forEach items="${items}" var="item" varStatus="loop">
    <h2 id="item-desc-${loop.index}">${item.itemDescription}</h2>
    <input class="big-button" data-desc-ref="item-desc-${loop.index}" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">
    </c:forEach>


    Above I added code to generate a unique id (e.g. id="item-desc-0") on each <h2> element. On the button, I added a data- attribute to reference the ID of the <h2> so we can retrieve it later.



    Now we change your status function to find the element by the ID specified in the data attribute, and get its innerText (the content between the opening and closing tags).



    Then, you can pass that text to the function that copies it to the clipboard, reference above in my comment.



      function status(clickedBtn) 
    {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;
    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }


    Here's a working example. I had to put in sample HTML that would be generated by your loop.






    function copyToClipboard(text) {
    if (window.clipboardData && window.clipboardData.setData) {
    // IE specific code path to prevent textarea being shown while dialog is visible.
    return clipboardData.setData("Text", text);

    } else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
    var textarea = document.createElement("textarea");
    textarea.textContent = text;
    textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
    document.body.appendChild(textarea);
    textarea.select();
    try {
    return document.execCommand("copy"); // Security exception may be thrown by some browsers.
    } catch (ex) {
    console.warn("Copy to clipboard failed.", ex);
    return false;
    } finally {
    document.body.removeChild(textarea);
    }
    }
    }

    function status(clickedBtn) {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }

    <h2 id="item-desc-0">Testing 0</h2>
    <input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-1">Testing 1</h2>
    <input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-2">Testing 2</h2>
    <input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">








    function copyToClipboard(text) {
    if (window.clipboardData && window.clipboardData.setData) {
    // IE specific code path to prevent textarea being shown while dialog is visible.
    return clipboardData.setData("Text", text);

    } else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
    var textarea = document.createElement("textarea");
    textarea.textContent = text;
    textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
    document.body.appendChild(textarea);
    textarea.select();
    try {
    return document.execCommand("copy"); // Security exception may be thrown by some browsers.
    } catch (ex) {
    console.warn("Copy to clipboard failed.", ex);
    return false;
    } finally {
    document.body.removeChild(textarea);
    }
    }
    }

    function status(clickedBtn) {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }

    <h2 id="item-desc-0">Testing 0</h2>
    <input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-1">Testing 1</h2>
    <input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-2">Testing 2</h2>
    <input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">





    function copyToClipboard(text) {
    if (window.clipboardData && window.clipboardData.setData) {
    // IE specific code path to prevent textarea being shown while dialog is visible.
    return clipboardData.setData("Text", text);

    } else if (document.queryCommandSupported && document.queryCommandSupported("copy")) {
    var textarea = document.createElement("textarea");
    textarea.textContent = text;
    textarea.style.position = "fixed"; // Prevent scrolling to bottom of page in MS Edge.
    document.body.appendChild(textarea);
    textarea.select();
    try {
    return document.execCommand("copy"); // Security exception may be thrown by some browsers.
    } catch (ex) {
    console.warn("Copy to clipboard failed.", ex);
    return false;
    } finally {
    document.body.removeChild(textarea);
    }
    }
    }

    function status(clickedBtn) {
    var text = document.getElementById(clickedBtn.dataset.descRef).innerText;

    copyToClipboard(text);

    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';
    }

    <h2 id="item-desc-0">Testing 0</h2>
    <input class="big-button" data-desc-ref="item-desc-0" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-1">Testing 1</h2>
    <input class="big-button" data-desc-ref="item-desc-1" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">

    <h2 id="item-desc-2">Testing 2</h2>
    <input class="big-button" data-desc-ref="item-desc-2" type="button" value="Add item copied to clipboard" id="btn" onclick="status(this)">






    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited Nov 11 at 22:30

























    answered Nov 11 at 22:24









    Cᴏʀʏ

    79.8k15131168




    79.8k15131168












    • @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
      – daisygal
      Nov 11 at 23:12












    • I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
      – Cᴏʀʏ
      Nov 12 at 20:10










    • @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
      – daisygal
      Nov 14 at 23:47










    • You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
      – Cᴏʀʏ
      Nov 15 at 1:32


















    • @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
      – daisygal
      Nov 11 at 23:12












    • I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
      – Cᴏʀʏ
      Nov 12 at 20:10










    • @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
      – daisygal
      Nov 14 at 23:47










    • You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
      – Cᴏʀʏ
      Nov 15 at 1:32
















    @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
    – daisygal
    Nov 11 at 23:12






    @Cory, thanks so much for this! I tried it and unfortunately, it's not working. When do you set the index number for the for-each loop?
    – daisygal
    Nov 11 at 23:12














    I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
    – Cᴏʀʏ
    Nov 12 at 20:10




    I supplied some modified JSTL code that renders the HTML a little differently. Did you remember to update your JSTL?
    – Cᴏʀʏ
    Nov 12 at 20:10












    @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
    – daisygal
    Nov 14 at 23:47




    @Cory, You deserve the goldest of stars!!! THIS WORKED!!! wow you are incredible!!! thank you so much!! :)
    – daisygal
    Nov 14 at 23:47












    You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
    – Cᴏʀʏ
    Nov 15 at 1:32




    You're welcome! Please study it and understand it, and reach back if any part of it didn't make sense. It will be beneficial to fully understand why it works so you can learn from it.
    – Cᴏʀʏ
    Nov 15 at 1:32












    up vote
    0
    down vote













    Cory provides a very helpful link to the clipboard aspect, I thought I'd provide the info about how to target a clicked element.



    To achieve this, pass event to your onclick attribute, and use event.target to reference the clicked element. Here's a basic example:






    function copy(e) {
    alert(e.target.value)
    }

    <button onclick="copy(event)" value="copy this">copy this</button>
    <button onclick="copy(event)" value="copy that">copy that</button>





    To address your specific requirement, if you put item.itemDescription into the value attribute, then it will copy the text you want.






    share|improve this answer





















    • thanks so much! So since I already have something in my value attribute, is there another way around this?
      – daisygal
      Nov 11 at 22:26










    • @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
      – Frish
      Nov 11 at 22:32

















    up vote
    0
    down vote













    Cory provides a very helpful link to the clipboard aspect, I thought I'd provide the info about how to target a clicked element.



    To achieve this, pass event to your onclick attribute, and use event.target to reference the clicked element. Here's a basic example:






    function copy(e) {
    alert(e.target.value)
    }

    <button onclick="copy(event)" value="copy this">copy this</button>
    <button onclick="copy(event)" value="copy that">copy that</button>





    To address your specific requirement, if you put item.itemDescription into the value attribute, then it will copy the text you want.






    share|improve this answer





















    • thanks so much! So since I already have something in my value attribute, is there another way around this?
      – daisygal
      Nov 11 at 22:26










    • @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
      – Frish
      Nov 11 at 22:32















    up vote
    0
    down vote










    up vote
    0
    down vote









    Cory provides a very helpful link to the clipboard aspect, I thought I'd provide the info about how to target a clicked element.



    To achieve this, pass event to your onclick attribute, and use event.target to reference the clicked element. Here's a basic example:






    function copy(e) {
    alert(e.target.value)
    }

    <button onclick="copy(event)" value="copy this">copy this</button>
    <button onclick="copy(event)" value="copy that">copy that</button>





    To address your specific requirement, if you put item.itemDescription into the value attribute, then it will copy the text you want.






    share|improve this answer












    Cory provides a very helpful link to the clipboard aspect, I thought I'd provide the info about how to target a clicked element.



    To achieve this, pass event to your onclick attribute, and use event.target to reference the clicked element. Here's a basic example:






    function copy(e) {
    alert(e.target.value)
    }

    <button onclick="copy(event)" value="copy this">copy this</button>
    <button onclick="copy(event)" value="copy that">copy that</button>





    To address your specific requirement, if you put item.itemDescription into the value attribute, then it will copy the text you want.






    function copy(e) {
    alert(e.target.value)
    }

    <button onclick="copy(event)" value="copy this">copy this</button>
    <button onclick="copy(event)" value="copy that">copy that</button>





    function copy(e) {
    alert(e.target.value)
    }

    <button onclick="copy(event)" value="copy this">copy this</button>
    <button onclick="copy(event)" value="copy that">copy that</button>






    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Nov 11 at 22:13









    Frish

    814313




    814313












    • thanks so much! So since I already have something in my value attribute, is there another way around this?
      – daisygal
      Nov 11 at 22:26










    • @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
      – Frish
      Nov 11 at 22:32




















    • thanks so much! So since I already have something in my value attribute, is there another way around this?
      – daisygal
      Nov 11 at 22:26










    • @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
      – Frish
      Nov 11 at 22:32


















    thanks so much! So since I already have something in my value attribute, is there another way around this?
    – daisygal
    Nov 11 at 22:26




    thanks so much! So since I already have something in my value attribute, is there another way around this?
    – daisygal
    Nov 11 at 22:26












    @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
    – Frish
    Nov 11 at 22:32






    @daisygal sure, you could probably do something like use a parent selector and then find the h2 value from there.
    – Frish
    Nov 11 at 22:32












    up vote
    0
    down vote













    If h2 element exactly is on previous of button you can use like this.






    function status(clickedBtn) 
    {
    clickedBtn.value = "Copied to clipboard";
    clickedBtn.disabled = true;
    clickedBtn.style.color = 'white';
    clickedBtn.style.background = 'gray';

    //New Code
    copyToCliboard(clickedBtn.previousSibling);
    }
    function copyToCliboard(el) {
    if (document.body.createTextRange) {
    var range = document.body.createTextRange();
    range.moveToElementText(el);
    range.select();
    } else {
    var selection = window.getSelection();
    var range = document.createRange();
    range.selectNodeContents(el);
    selection.removeAllRanges();
    selection.addRange(range);
    }
    document.execCommand("copy");
    window.getSelection().removeAllRanges();
    }

    h2{
    display:inline;
    }

    <html>
    <head>
    </head>
    <body>
    <div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
    <div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
    </body>
    </html>








    share|improve this answer



























      up vote
      0
      down vote













      If h2 element exactly is on previous of button you can use like this.






      function status(clickedBtn) 
      {
      clickedBtn.value = "Copied to clipboard";
      clickedBtn.disabled = true;
      clickedBtn.style.color = 'white';
      clickedBtn.style.background = 'gray';

      //New Code
      copyToCliboard(clickedBtn.previousSibling);
      }
      function copyToCliboard(el) {
      if (document.body.createTextRange) {
      var range = document.body.createTextRange();
      range.moveToElementText(el);
      range.select();
      } else {
      var selection = window.getSelection();
      var range = document.createRange();
      range.selectNodeContents(el);
      selection.removeAllRanges();
      selection.addRange(range);
      }
      document.execCommand("copy");
      window.getSelection().removeAllRanges();
      }

      h2{
      display:inline;
      }

      <html>
      <head>
      </head>
      <body>
      <div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
      <div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
      </body>
      </html>








      share|improve this answer

























        up vote
        0
        down vote










        up vote
        0
        down vote









        If h2 element exactly is on previous of button you can use like this.






        function status(clickedBtn) 
        {
        clickedBtn.value = "Copied to clipboard";
        clickedBtn.disabled = true;
        clickedBtn.style.color = 'white';
        clickedBtn.style.background = 'gray';

        //New Code
        copyToCliboard(clickedBtn.previousSibling);
        }
        function copyToCliboard(el) {
        if (document.body.createTextRange) {
        var range = document.body.createTextRange();
        range.moveToElementText(el);
        range.select();
        } else {
        var selection = window.getSelection();
        var range = document.createRange();
        range.selectNodeContents(el);
        selection.removeAllRanges();
        selection.addRange(range);
        }
        document.execCommand("copy");
        window.getSelection().removeAllRanges();
        }

        h2{
        display:inline;
        }

        <html>
        <head>
        </head>
        <body>
        <div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
        <div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
        </body>
        </html>








        share|improve this answer














        If h2 element exactly is on previous of button you can use like this.






        function status(clickedBtn) 
        {
        clickedBtn.value = "Copied to clipboard";
        clickedBtn.disabled = true;
        clickedBtn.style.color = 'white';
        clickedBtn.style.background = 'gray';

        //New Code
        copyToCliboard(clickedBtn.previousSibling);
        }
        function copyToCliboard(el) {
        if (document.body.createTextRange) {
        var range = document.body.createTextRange();
        range.moveToElementText(el);
        range.select();
        } else {
        var selection = window.getSelection();
        var range = document.createRange();
        range.selectNodeContents(el);
        selection.removeAllRanges();
        selection.addRange(range);
        }
        document.execCommand("copy");
        window.getSelection().removeAllRanges();
        }

        h2{
        display:inline;
        }

        <html>
        <head>
        </head>
        <body>
        <div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
        <div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
        </body>
        </html>








        function status(clickedBtn) 
        {
        clickedBtn.value = "Copied to clipboard";
        clickedBtn.disabled = true;
        clickedBtn.style.color = 'white';
        clickedBtn.style.background = 'gray';

        //New Code
        copyToCliboard(clickedBtn.previousSibling);
        }
        function copyToCliboard(el) {
        if (document.body.createTextRange) {
        var range = document.body.createTextRange();
        range.moveToElementText(el);
        range.select();
        } else {
        var selection = window.getSelection();
        var range = document.createRange();
        range.selectNodeContents(el);
        selection.removeAllRanges();
        selection.addRange(range);
        }
        document.execCommand("copy");
        window.getSelection().removeAllRanges();
        }

        h2{
        display:inline;
        }

        <html>
        <head>
        </head>
        <body>
        <div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
        <div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
        </body>
        </html>





        function status(clickedBtn) 
        {
        clickedBtn.value = "Copied to clipboard";
        clickedBtn.disabled = true;
        clickedBtn.style.color = 'white';
        clickedBtn.style.background = 'gray';

        //New Code
        copyToCliboard(clickedBtn.previousSibling);
        }
        function copyToCliboard(el) {
        if (document.body.createTextRange) {
        var range = document.body.createTextRange();
        range.moveToElementText(el);
        range.select();
        } else {
        var selection = window.getSelection();
        var range = document.createRange();
        range.selectNodeContents(el);
        selection.removeAllRanges();
        selection.addRange(range);
        }
        document.execCommand("copy");
        window.getSelection().removeAllRanges();
        }

        h2{
        display:inline;
        }

        <html>
        <head>
        </head>
        <body>
        <div><h2>Text1</h2><button onclick="status(this)">Copy</button></div>
        <div><h2>Text2</h2><button onclick="status(this)">Copy</button></div>
        </body>
        </html>






        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Nov 12 at 7:02

























        answered Nov 12 at 6:33









        RGhanbari

        944




        944






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.





            Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


            Please pay close attention to the following guidance:


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53253702%2fhow-to-copy-text-which-is-in-a-for-each-loop-to-clipboard-when-button-is-click%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Florida Star v. B. J. F.

            Danny Elfman

            Lugert, Oklahoma