Как сделать многоточие из бумаги
И в чём проблема? Примитивный алгоритм, реализуемый банальным if.
У нас 7 клеток. Соответственно, рассматриваем 4 случая:
1. Стараниц не больше 7 - тупо выводим все номера страниц без многоточий.
2. Мы находимся на одной из первых 3 страниц - выводим номера 1..5, многоточие, номер последней страницы.
3. Мы находимся на одной из последних 3 станиц: выводим 1, многоточие, номера последних 5 страниц.
4. Во всех остальных случаях выводим 1, многоточие, номера предыдущей, текущей, следующей страницы, многоточие, номер последней страницы.
А то, что многоточие не является ссылкой - так это банальный вывод не тега [a], а [span] или [div]. Или даже [a], но без атрибута href.
Диало́г — литературная или театральная форма устного или письменного обмена высказываниями (репликами, вопросами и ответами) между двумя и более людьми, также бывает письменный диалог между двумя или более людьми посредством написания текста в письмах или другими методами; специфическая форма общения и коммуникации, диалог — это вопросы и ответы двух и более оппонентов, участвующих в разговоре или обсуждении чего-либо.
Википедия
Почти во всех книгах присутствует разговоры между персонажами (диалоги) и их мысли. Но очень часто натыкаюсь в книгах на неправильное их оформление. Вот и решила еще раз заострить на этом внимание.
Оформление диалогов
При оформлении диалогов используются пробелы и тире. Однако часто пробелы просто игнорируют или тире пишут слитно с последующим текстом, особенно первое. А некоторые просто ставят дефис вместо тире. Ниже приведен пример из рассказа, опубликованного на сайте.
-Уважаемый,-поперхнулся Харон,- мне это точно не грозит.
Пробелы ставятся после каждого тире и перед всеми, кроме первого, тоже должен иметься пробел. Также пробелы ставятся после всех знаков препинания, кроме дефисов (не путать с тире).
— Уважаемый, — поперхнулся Харон, — мне это точно не грозит.
Если с пробелами и тире все понятно и просто, то со знаками препинания и строчными или заглавными буквами возникает путаница, что приводит к ошибкам при оформлении диалогов. Но начнем разбираться по порядку:
Запятая и строчная буква
В русском языке, предложение, содержащее прямую речь и слова автора, является сложным бессоюзным. Вспоминая пунктуацию сложных предложений, можно сделать вывод, что между частями ставится запятая, а не точка. Следовательно, когда речь персонажа закончилась и должна стоять точка, но дальше имеются слова автора, ставится запятая. Исключением являются имена собственные.
— Спасибо, милорд, вы вовремя подоспели иначе мне бы уже не жить, — и рыцарь поднял забрало, под которым оказалось лицо двадцатилетнего юноши.
— Ушедших не вернуть, Стиви, — Дана свернула губы в трубочку и сочувственно склонила голову набок.
Точка и заглавная буква
Существует только один случай, в котором точку можно употребить при написании прямой речи.
Если слова автора никак не комментируют прямую речь, то ставится точка.
То есть, опираясь на случай с запятой, можно сказать, что это не сложное бессоюзное предложение.
— Ты уж постарайся. — Блондин продолжил свой путь.
Слова автора не содержат ничего, что говорило бы о том, к кому шло обращение, с какой интонацией и какими эмоциями. Это просто два разных предложения, никак не поясняющие друг друга.
P.S. Но если поставить запятую и продолжить писать с маленькой буквы, вы никогда не ошибётесь. Точки и большие буквы — уже на усмотрение автора.
Вопросительный знак и строчная буква
Иногда можно встретить вот такое предложение:
-Куда теперь попал, Асклепий?-Спросила Смерть.
С вопросительными предложениями всё обстоит достаточно просто: слова автора после них всегда пишутся с маленькой буквы. Исключением являются только имена собственные, которые всегда пишутся с большой буквы.
— Куда теперь попал, Асклепий? — спросила Смерть.
— Как ты, друг? — Гарри швырнул стерильные перчатки в мусорное ведро.
Восклицательный знак и строчная буква
С восклицательными предложениями ситуация аналогична: слова автора опять идут с маленькой буквы, если не стоит имя собственное.
— Спускайтесь аккуратней, миссис Винсент! — крикнула Дана, когда клиентка пошатнулась на каблуках.
— Вот повезло! — Сергей светился от радости.
Многоточие и строчная буква
Также среди остальных знаков реже, но все же встречается многоточие. Оно свидетельствует о неуверенности персонажа или незаконченности мыслей, или когда говорящего перебивают. Но и с этим знаком все обстоит просто: после многоточия слова автора пишутся с маленькой буквы, если не начинаются с имени собственного.
Теперь рассмотрим оформление диалогов, в которых слова автора располагаются внутри прямой речи.
В таких предложениях уже нужно думать над тем, с какой буквы начать писать вторую часть речи персонажа, да и опять могут возникнуть вопросы по поводу знаков препинания перед словами автора. Разберём подробно каждый случай.
Слова автора, расположенные внутри одного предложения персонажа
Первый случай: персонаж не закончил и одного своего предложения, а автор уже оставляет свой комментарий к его словам.
В данном случае получается, что перед словами автора будет ставиться запятая и текст после неё, естественно, пишется с маленькой буквы. Но, так как персонаж не закончил предложение, в конце слов автора снова ставится запятая, и речь продолжается с маленькой буквы. То есть, чтобы было проще понять: убрав авторский комментарий, мы получим обыкновенное предложение, возможно, простое. Как и ранее, исключение составят только имена собственные.
— Ага, — подтвердил Харон, — вредные привычки для бессмертного это круто!
— И звать его, — Тристан перевёл взгляд на их лидера, — Илларион.
Убирая авторские комментарии в обоих случаях, мы получаем одно предложение, которое, по сути, никак не делится на два. А если поделить, то выйдет откровенный бред.
Второй случай: не всегда при написании можно поставить запятую после первой части, иногда так и тянет влепить многоточие. Данный случай почти не отличается от предыдущего, только на месте первой запятой будет стоять многоточие. Остальные знаки и строчные буквы не меняются. С именами собственными та же ситуация.
— Я понимаю тебя, но всё же. — большая яркая бабочка опустилась ему на палец, заставив на секунду замолкнуть, — постарайся следовать принятым правилам.
— Ну. — Илларион перевёл безразличный взгляд на провинившуюся парочку, — а мне что делать прикажете?
— Тогда. — он хитро улыбнулся, — Вирджин и пояснит всё.
Повествование. Слова автора расположены между двумя предложениями
Теперь, когда разобраны два самых затруднительных случая, пойдём по стандартной схеме. Как обычно, начнем с простых повествовательных предложений. С ними дела обстоят так же, как и в случае, где после слов автора персонаж ничего больше не высказывал. То есть, говоря проще, перед комментарием автора ставится запятая, и текст продолжает писаться с маленькой буквы. В конце слов автора ставится точка, и дальше текст пойдёт с большой буквы. В виде исключений снова выступают имена собственные.
— Жалко Гермиону, — посочувствовал Уизли. — Хотя она, конечно, и задавака.
— Не моё дело, — Селевк был спокоен и безразличен, впрочем, как и всегда. — И не надо дуть губы на каждый мой отказ.
Тут всё просто, только добавилось ещё одно предложение после слов автора.
Вопрос. Слова автора между двумя предложениями
Случай почти не отличается от вопросов, рассматриваемых ранее. Снова появляется дополнительное предложение после слов автора, которое, кстати, может и не являться вопросом. Сейчас всё внимание стоит сконцентрировать на первой части, идущей до авторского комментария. Именно она заканчивается вопросом. Слова автора пишутся с маленькой буквы, в конце ставится точка, а новое предложение пишется с большой буквы. Имена собственные снова исключаются из общих правил.
— Ты что, интернет не читаешь? — удивился Петрович и отряхнул от сахарной пыли крепкие рабочие руки. — В тюрьму писак уже год как не сажают. Тюрьма ещё никого не перевоспитала.
— А тогда ты о чём думала? — Тристан недовольно глянул на шатенку, которую нисколько не мучила совесть. — Думаешь, я снова так легко тебе поверю?
Восклицание. Слова автора между двумя предложениями
Вот так неправильно писать.
-Твою ж мать!- Горько высказалась Смерть.- Фортуна на его стороне.
После восклицательного знака слова автора пишутся с маленькой буквы. В конце ставится точка, а новое предложение будет писаться с большой буквы. Имена собственные — исключение.
— Твою ж мать! — горько высказалась Смерть. — Фортуна на его стороне.
— Отпусти, говорю тебе! — Лина не оставляла попыток не только вырваться, но и оглушить блондина своим звонким голосом. — Отпусти!
Многоточие. Слова автора между двумя предложениями
А теперь пришло время разобраться еще с одним знаком препинания — многоточие. В одном из ранее разобранных случаев было ясно видно, что знак этот не так прост. То ли после него речь будет с большой буквы, то ли с маленькой. У многих часто возникает путаница в этих случаях. Ранее рассматривалось многоточие как знак, свидетельствующий о незаконченности предложения с имеющимся продолжением после слов автора. Сейчас же поговорим о том, когда предложение всё же закончено или не имеет логического завершения, или у говорящего произошла в голове быстрая смена мыслей, что напрямую отразилось в его речи. В этом случае после многоточия слова автора по-прежнему пишутся с маленькой (строчной) буквы, в конце ставится точка, а речь будет писаться с прописной (большой) буквы. Имена собственные — исключение.
— Эх. — тяжело вздохнул юноша, подпирая голову рукой. — И что мне с вами делать?
— Ты достал. — Мэрикейт смотрела полным ненависти взглядом на парня. — Продолжишь и дальше приставать — убью.
Двоеточие. Знак после слов автора
Однако слова автора, прерывающие прямую речь, которые кажутся на первый взгляд практически аналогичными тем, которые не прерывают, имеют и ещё свои подводные камни. Если раньше были рассмотрены только те случаи, когда после слов автора ставится точка или запятая, то следует упомянуть и двоеточие. Когда и где ставится знак двоеточия: если последнее предложение слов автора комментирует или поясняет ту часть речи персонажа, которая идёт после них, ставится двоеточие, тире, а предложение пишется с прописной буквы; если в авторских словах внутри прямой речи имеются два глагола со значением высказывания, из которых один относится к первой части прямой речи, а другой — ко второй, то после слов автора ставятся двоеточие и тире, причём первое слово второй части начинается с прописной буквы.
— А я же тебе говорила, что он связан с Советом! — не унималась Каролина, укоризненно смотря на опечаленного парня. Такой его вид просто не мог не вызывать жалости, отчего у девочки возникло желание успокоить друга: — Ну. ты, Ил, не расстраивайся так.
— Я думаю, — нерешительно проговорил он и добавил: — Мне нелегко принять сразу это решение.
С оформлением диалогов немного разобрались, а теперь остановимся на правилах оформления мыслей.
Оформление мыслей
Главное — мысль не может услышать каждый, как обыкновенную речь. Все неозвученные фразы персонажа оформляются так же, как и в обычной речи, но разница только в том, что отсутствует тире в самом начале и слова заключаются в кавычки. Но и тут имеются свои трудности, потому что в кавычках пишется не всё.
Слова автора после мыслей. Постановка кавычек
Пример хорошо отражает все нюансы, оговоренные ранее: первое тире отсутствует, слова автора пишутся за пределами кавычек. Также обратим внимание ещё на несколько вещей: открывающаяся кавычка пишется слитно с первым словом, то есть в отличие от прямой речи здесь не ставится пробел; тире, стоящее после прямой речи, пишется после закрывающей кавычки и отделяется от неё пробелом. В остальном никаких изменений не произошло.
Но особенность мыслей ещё в том, что не все знаки ставятся внутри кавычек, поэтому более подробно остановимся на этом.
Знак препинания внутри кавычек
Просто нужно запомнить, что многоточие, вопросительный и восклицательный знаки всегда пишутся внутри кавычек!
Знак препинания за пределами кавычек
Еще раз напомню, что при оформлении мыслей точка не ставится. А ставится запятая, но именно её постановка требует отдельного внимания. Запятая — единственный знак, стоящий после закрывающей кавычки. Никогда она не может писаться внутри них.
Здесь хотелось бы обратить внимание на то, что запятая пишется, не отделяясь пробелом от закрывающей кавычки. Перед тире пробел ставится, а дальше всё оформляется так же, как и с прямой речью.
Мысли без слов автора. Постановка кавычек
Редко, но бывают случаи, когда мысли персонажа никак не комментируются. В этом случае знаки в конце предложений пишутся внутри кавычек.
Однако из этого правила есть одно маленькое исключение. Если нет слов автора, а предложение повествовательное, без каких-либо посторонних интонаций, то запятую в конце уже не поставишь. Следовательно, нужна точка. Этот знак препинания ставится только после закрывающей кавычки и только в том случае, если слова автора отсутствуют.
В этом случае отсутствует тире. Точка, как и запятая, пишется слитно с закрывающей кавычкой, не отделяясь пробелом.
Слова автора внутри и после мыслей. Постановка кавычек
Данный случай основывается на тех же правилах, что и все другие, но сложность только в том, что не всегда понятно, когда слова автора пишутся внутри кавычек, а когда за их пределами.
Слова автора внутри мыслей персонажа
Слов автора, как известно, может быть неограниченное количество, но они обязаны чередоваться со словами персонажа. В данном случае с мыслями. А это значит, что в конце окажутся либо слова автора, либо мысль персонажа. Однако сейчас рассмотрим случай, когда последней располагается мысль. В данной ситуации и авторский комментарий будет расположен внутри кавычек.
Слова автора внутри и после мыслей персонажа
А теперь рассмотрим более сложный вариант: мысли-слова-мысли-слова. Вся эта цепочка заключается в кавычки, кроме последних слов автора. В данном случае такая же ситуация, как и в пункте с авторским комментарием после мыслей, но до этого имеется ещё некоторое количество мыслей, разорванных словами автора.
Определяет параметры видимости текста в блоке, если текст целиком не помещается в заданную область. Возможны два варианта: текст обрезается; текст обрезается и к концу строки добавляется многоточие. text-overflow работает в том случае, если для блока значение свойства overflow установлено как auto , scroll или hidden .
Синтаксис
text-overflow: clip | ellipsis
Значения
HTML5 CSS3 IE Cr Op Sa Fx
Результат данного примера показан на рис. 1.
Рис. 1. Многоточие в конце текста
Браузеры
Opera с версии 9.0 до версии 11.0 использует нестандартное свойство -o-text-overflow .
CSS многоточие после нескольких строк
В CSS очень просто обрезать текст в одной строке для некоторой ширины и отобразить многоточие.
CSS-свойство line-clamp помогает подрезать текст на определенное количество строк.
Синтаксис
line-clamp может принимать следующие значения:
А как это сделать с text-overflow ?
Для text-overflow действительно есть значение ellipsis для ограничения текста:
Вот здесь в игру вступает line-clamp . Надо заметить, что для придётся использовать комбинацию из трех свойств:
Это неполная поддержка браузерами. Тут используется префикс -webkit- (который, как ни странно, работает во всех основных браузерах, но это не точно).
Как обычно, уточнить поддержку свойства браузерами можно на странице Caniuse.
Как я могу сделать переполнение текста: многоточие на двух строках?
У меня есть контейнер, в котором текст может расширяться до двух строк, высотой 40 пикселей и размером шрифта 18 пикселей. Когда я делаю:
Тогда пунктирная линия отображается правильно, но срезается на одной линии. Когда я делаю только:
Тогда он правильно показывает 2 строки, но в конце нет ". ". Как мне добиться этого, чтобы он правильно использовал обе строки И заканчивался ". " во второй строке?
4 ответа
Добавьте span в контейнер, который будет содержать текст:
Добавьте этот CSS:
Измените размер контейнера, и вы увидите, что многоточие отображается только при необходимости.
Должен работать во всех современных браузерах.
Чистый метод css на основе -webkit-line-clamp:
Просто хочу добавить свои два цента. Ближайшим чистым решением CSS, которое работает, является метод -webkit-line-clamp , но он ограничен браузерами webkit и является остатком старой реализации Flexbox (которая может быть удалена в будущем).
Возможно, вам стоит пересмотреть, действительно ли вам нужны многоточия в вертикальном переполненном тексте.
Вместо этого я предлагаю использовать текстовое поле с возможностью прокрутки. Я считаю, что это лучшее решение по трем причинам:
- Работает во всех основных браузерах
- Никаких обходных путей css, хаков или javascript не требуется
- Хорошо сообщает пользователю, что текст обрезан, но дает им возможность прокручивать его, если они хотят — плюс, пользователи уже привыкли к вертикальным полосам прокрутки
Вот пример кода для текстового поля:
Если бы мне пришлось выбирать, я бы использовал решение javascript, подобное Succint, которое удаляет слова после определенное количество и добавляет в конце . Это замечательно, если вы используете React, потому что вы можете реализовать весь код, необходимый внутри компонента, как функцию, и если вам нужен исходный текст, у вас все еще есть его как значение свойства.
Вы можете сделать это с помощью -webkit-line-clamp . Но взлом нужен. Вам нужно установить высоту div так, чтобы он мог вместить только две строки.
Определяет параметры видимости текста в блоке, если текст целиком не помещается в заданную область. Возможны два варианта: текст обрезается; текст обрезается и к концу строки добавляется многоточие. text-overflow работает в том случае, если для блока значение свойства overflow установлено как auto , scroll или hidden .
Синтаксис
text-overflow: clip | ellipsis
Значения
HTML5 CSS3 IE Cr Op Sa Fx
Результат данного примера показан на рис. 1.
Рис. 1. Многоточие в конце текста
Браузеры
Opera с версии 9.0 до версии 11.0 использует нестандартное свойство -o-text-overflow .
CSS многоточие после нескольких строк
В CSS очень просто обрезать текст в одной строке для некоторой ширины и отобразить многоточие.
CSS-свойство line-clamp помогает подрезать текст на определенное количество строк.
Синтаксис
line-clamp может принимать следующие значения:
А как это сделать с text-overflow ?
Для text-overflow действительно есть значение ellipsis для ограничения текста:
Вот здесь в игру вступает line-clamp . Надо заметить, что для придётся использовать комбинацию из трех свойств:
Это неполная поддержка браузерами. Тут используется префикс -webkit- (который, как ни странно, работает во всех основных браузерах, но это не точно).
Как обычно, уточнить поддержку свойства браузерами можно на странице Caniuse.
Как я могу сделать переполнение текста: многоточие на двух строках?
У меня есть контейнер, в котором текст может расширяться до двух строк, высотой 40 пикселей и размером шрифта 18 пикселей. Когда я делаю:
Тогда пунктирная линия отображается правильно, но срезается на одной линии. Когда я делаю только:
Тогда он правильно показывает 2 строки, но в конце нет ". ". Как мне добиться этого, чтобы он правильно использовал обе строки И заканчивался ". " во второй строке?
4 ответа
Добавьте span в контейнер, который будет содержать текст:
Добавьте этот CSS:
Измените размер контейнера, и вы увидите, что многоточие отображается только при необходимости.
Должен работать во всех современных браузерах.
Чистый метод css на основе -webkit-line-clamp:
Просто хочу добавить свои два цента. Ближайшим чистым решением CSS, которое работает, является метод -webkit-line-clamp , но он ограничен браузерами webkit и является остатком старой реализации Flexbox (которая может быть удалена в будущем).
Возможно, вам стоит пересмотреть, действительно ли вам нужны многоточия в вертикальном переполненном тексте.
Вместо этого я предлагаю использовать текстовое поле с возможностью прокрутки. Я считаю, что это лучшее решение по трем причинам:
- Работает во всех основных браузерах
- Никаких обходных путей css, хаков или javascript не требуется
- Хорошо сообщает пользователю, что текст обрезан, но дает им возможность прокручивать его, если они хотят — плюс, пользователи уже привыкли к вертикальным полосам прокрутки
Вот пример кода для текстового поля:
Если бы мне пришлось выбирать, я бы использовал решение javascript, подобное Succint, которое удаляет слова после определенное количество и добавляет в конце . Это замечательно, если вы используете React, потому что вы можете реализовать весь код, необходимый внутри компонента, как функцию, и если вам нужен исходный текст, у вас все еще есть его как значение свойства.
Вы можете сделать это с помощью -webkit-line-clamp . Но взлом нужен. Вам нужно установить высоту div так, чтобы он мог вместить только две строки.
Читайте также: