Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
Shiningemerald
 Аватар для Electroflower
384 / 117 / 22
Регистрация: 05.01.2012
Сообщений: 951

Скопировать текст из div по клику на этот div

13.01.2021, 19:03. Показов 3892. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как скопировать текст из div по клику на этот div?

вот моя попытка:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
function divCopy(divToCopy)
    {
        debugger;
        let divText = divToCopy.innerHTML;
        
        const modifyCopy = (e) => 
            {
                e.clipboardData.setData('text/plain',  divText  );
                document.execCommand('copy');
                console.log('copied');
                e.preventDefault();
            };
 
        document.addEventListener('copy', modifyCopy);
 
    }
Добавлено через 36 секунд
HTML5
1
<div id="string" class="stringbook" hidden="true" onclick="divCopy(this);"></div>
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.01.2021, 19:03
Ответы с готовыми решениями:

Как отделить отдельный блок div со всем содержимым в нём html коде от всего кода, в котором этот div находится?
Здравствуйте. Есть много файлов html (70 штук) и в нём html код, такова плана: https://pastebin.com/LVSEx8em . Нужно автоматически отделить...

Скопировать текст из div по нажатию на кнопку
Приветствую. Есть div, в нем текст (строка символов). Хотелось бы по нажатию на кнопку получить содержимое этого дива в буфер обмена для...

Если совпадает текст введённый в input и div, то скрыть данный div
Изучаю jquery и решил сделать следующее: Я ввожу в input какой то текст и если он совпадает с текстом в заранее выбранных дивах то эти дивы...

6
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
14.01.2021, 08:00
Здравствуйте.
Electroflower, устаревший метод execCommand прекрасно работает и сам по себе:
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
</head>
<body>
    <div>divToCopy</div>
    <script>
        /**
         * Навесить на HTML-элемент обработчик события click.
         * По клику копировать содержимое HTML-элемента.
         * @param {HTMLElement} divToCopy HTML-элемент, на который надо навесить обработчик клика
         */
        function divCopy(divToCopy) {
            function modifyCopy(e) {
                let divText = divToCopy.innerHTML;
                document.execCommand('copy', false, divText);
                console.log('copied');
            }
 
            document.addEventListener('click', modifyCopy);
        }
 
        divCopy(document.querySelector("div"));
    </script>
</body>
</html>
Там нужно было разобраться, что мы вообще хотим делать. А хотим мы навесить обработчик клика. Именно в tool-функции.
2
 Аватар для web_coder2
755 / 359 / 100
Регистрация: 04.10.2018
Сообщений: 548
14.01.2021, 08:11
Привет amr-now, чего-то не копирует, в консоли пишет скопировано а в буфере нет (

Добавлено через 2 минуты
Я тут тоже вариант написал ну так на всякий случай

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
</head>
<body>
<div class="textForCopy"><pre>
Отражения, кривляясь,
 
Вырываются на волю,
 
Хладнокровно улыбаясь
 
Или плача, но без боли…
 
Зеркала следят за нами,
 
Научившись даже слушать,
 
Быть и мыслями, и снами,
 
Искажая наши души.
 
Тонут в зеркале желанья,
 
Замедляются движенья….
 
Нас отдали на закланье,
 
Нас поймали отраженья…
</pre></div>
 
<button id="copyWith-execCommand">Copy with document.execCommand('copy')</button>
<button id="copyWith-navigator-clipboard">Copy with navigator.clipboard</button>
<script>
document.querySelector("button#copyWith-execCommand").onclick = _ => copyWith_execCommand()
document.querySelector("button#copyWith-navigator-clipboard").onclick = _ => copyWith_NavigatorClipboard()
 
const textForCopy = document.querySelector('div.textForCopy');
 
const message_success = "Копирование в буфер выполенено, жмите CTRL+V чтобы увидеть что там"
const message_unsuccess = "Копирование в буфер не выполнено"
 
var getSelectionRange = containerText => {
    if (document.selection) { // IE
        var range = document.body.createTextRange();
        range.moveToElementText(containerText);
        range.select();
    } else if (window.getSelection) {
        var range = document.createRange();
        range.selectNode(containerText);
        window.getSelection().removeAllRanges();
        window.getSelection().addRange(range);
    }
    return range
}
 
var copyWith_execCommand = _ =>{
    try {
        var range = getSelectionRange(textForCopy)
        var successful = document.execCommand('copy');
        window.getSelection().removeRange(range)
        if(successful)
            alert(message_success)
        else
            alert(message_unsuccess)
    } catch (err) {
        alert(`${message_unsuccess} Ошибка: ${err.message}`);
    }
}
 
var copyWith_NavigatorClipboard = _ => {
    if(!navigator.clipboard){
        alert("navigator.clipboard undefined запустите пример на сервере с https")
        return
    }
 
    navigator.clipboard.writeText(textForCopy.children[0].innerHTML).then(
    _ => alert(message_success),
    e => alert(message_unsuccess))
}
</script>
</body>
</html>
2
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
14.01.2021, 08:20
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
</head>
 
<body>
    <div>divToCopy Test</div>
    <script>
        /**
         * Навесить на HTML-элемент обработчик события click.
         * По клику копировать содержимое HTML-элемента.
         * @param {HTMLElement} divToCopy HTML-элемент, на который надо навесить обработчик клика
         */
        function divCopy(divToCopy) {
            function modifyCopy(e) {
                let divText = this.innerHTML;
                let tempInput = document.createElement("input");
                tempInput.value = divText;
                document.body.appendChild(tempInput);
                tempInput.select();
                document.execCommand("copy");
                document.body.removeChild(tempInput);
                console.log('copied');
            }
 
            divToCopy.addEventListener('click', modifyCopy);
        }
 
        divCopy(document.querySelector('div'));
    </script>
</body>
</html>
Добавлено через 1 минуту
web_coder2, да. Там остался предыдущий буфер обмена.
На SO подсказали создавать временное поле ввода.
2
 Аватар для web_coder2
755 / 359 / 100
Регистрация: 04.10.2018
Сообщений: 548
14.01.2021, 09:03
немного не заметил

JavaScript
1
2
3
    navigator.clipboard.writeText(textForCopy.children[0].innerHTML).then(
    _ => alert(message_success),
    e => alert(message_unsuccess))
поменять на

JavaScript
1
2
3
    navigator.clipboard.writeText(textForCopy.children[0].innerHTML).then(
    _ => alert(message_success),
    err => alert(`${message_unsuccess} Ошибка: ${err.message}`)
Добавлено через 4 минуты
Привет Electroflower извините что не поздоровался с Вами!

Добавлено через 38 минут
И эту функцию
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
var getSelectionRange = containerText => {
    if (document.selection) { // IE
        var range = document.body.createTextRange();
        range.moveToElementText(containerText);
        range.select();
    } else if (window.getSelection) {
        var range = document.createRange();
        range.selectNode(containerText);
        window.getSelection().removeAllRanges();
        window.getSelection().addRange(range);
    }
    return range
}
можно переписать так

JavaScript
1
2
3
4
5
6
7
8
9
10
var getSelectionRange = containerText => {
    var range
    if (window.getSelection) {
        range = document.createRange();
        range.selectNode(containerText);
        window.getSelection().removeAllRanges();
        window.getSelection().addRange(range);
    }
    return range
}
она была скопирована из примеров которые работают под ie, но я ээээ нууу ... вобщем под ie мой пример работать не будет
1
Shiningemerald
 Аватар для Electroflower
384 / 117 / 22
Регистрация: 05.01.2012
Сообщений: 951
15.01.2021, 19:02  [ТС]
amr-now, web_coder2, спасибо вам! Буду разбираться!)
0
409 / 162 / 32
Регистрация: 26.11.2019
Сообщений: 434
16.01.2021, 05:35
Electroflower, вы вопрос непонятно задали, скопировать по клику текст из элемента - это одно, а скопировать выделенный пользователем текст - это совсем другое.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.01.2021, 05:35
Помогаю со студенческими работами здесь

Как растянуть основной div до футера и разместить текст ровно центру этого div?
Всем привет, решил попробовать создать простейший резиновый сайт и чтобы футер был привязан внизу, чтобы не писать стандартную форму...

Текст и div. Сделать текст поверх div`a
Написать текст внутри div`a, у которого ширина равна 2px. То есть текст должен стоять поверх этого div`a, а не после него. &lt;div...

Пишу парсер Bash.Org.Ru. Там текст находится в блоках <div></div>. Помогите, пожалуйста, написать регулярное выражение для извлечения текста из блоков
Плиз) Добавлено через 7 минут string parse;//вот сюда надо написать регулярное выражение, а я не понимаю... ...

Вычисление выражения с=(a+b mod a*4+b div a) div 2-a div 160
Пожалуйста, посмотрите на код, уввжаемые! нужно вычислить такое выражение: с=(a+b mod a*4+b div a) div 2-a div 160 У меня неверно...

CSS!? Div в div'e, как не потерять позиции css внутреннего div'a при изменении размера браузера?
вот когда изменяю размер браузера, то внутренний div не хочет изменяться вместе с контейнером, а контейнер изменяется? .container{ ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru