• Эффективный лендинг и что есть SEO в отношении лендинга?

    xmoonlight
    @xmoonlight
    https://sitecoder.blogspot.com
    Скажу кратко: эффективный лендинг с точки зрения:

    1. SEO/ПС: это много релевантно-семантического текста в скрытых блоках, которые могут читать пользователи после развёртывания (спойлеры, вкладки, аккордионы, слайдеры и прочее). Тексты формируются так, чтобы страница лендинга содержала максимальное количество целевых поисковых запросов, включая синонимы.

    2. Аудитории (потенциальные клиенты): WOW-эффект, стильный вид, уникальность товара или услуги на рынке, удобство навигации, новшества в товарах/услугах, низкие цены, высокие гарантии, "прозрачность" и полнота информации, возможность выбора (модели, цвета, тарифы, бандлы, компектации и т.д.), известность бренда и т.д.
    Ответ написан
    Комментировать
  • Эффективный лендинг и что есть SEO в отношении лендинга?

    @DP-Studio
    20 лет веб-разработки
    Первое. Кто сказал, что лендинг не для органики как принцип? Можно пускать лэндинг в СЕО, если лэндинг постоянный, а не на неделю под одну акцию. И, кстати говоря, иногда результаты СЕО для лэндингов гораздо выше чем для многостраничников, ибо мусора мало. Ну это так, к слову. Если вы решили ваш Лэндинг по СЕО не двигать, а ограничиться только контекстом, том никакой оптимизации под ключи делать не надо и вы правы - юзер пришел по контексту, а задача лэндинга взять за я... и удержать (в качестве первого этапа, как правило взять лид. Особенно если это не торговля китайской копией вьетнамских часов).

    Второе. Наличие поисковой оптимизации не требуется, но смысловая связь с вашими обьявлениями в контексте быть обязана. Если юзер пришел по "Дешевая мебель на заказ" и первое что увидел - "Диваны категории Люкс" - вы потеряли деньги. То есть до сгиба юзер должен увидеть подтверждение того, по какому ключу он пришел.

    Третье. Да, вы правы - ключевики это и есть семантическое ядро. На тему "как собрать практически" в принципе куча материала в инете, достаточно погуглить. Общий принцип простой - идем на вордстатс, сеопульт или еще куда-нить и начинаем собирать ключи. Придумываете несколько ключевых фраз за клиента и разворачиваете в инструменте. Например "Купить мебель" смотрите во что разворачивается и особое внимание уделяете НЕПОДХОДЯЩИМ запросам (ну к примеру купить мебель для куклы барби, приму в дар мебель, фото, видео, рефераты, своими руками и прочий нецелевой траффик). Всё это аккуратненько в минус слова готовите. Откройте какойнить эксельчик и по каждой категории (ну для лэнда это не очень важно, там как правило 1 категория, но тем не менее) собирайте разворачиваемые ключевики. Высокочастотники старайтесь отсечь, разворачивайте их вглубь. Вряд ли тратить деньги на запрос "купить мебель" целесообразно. Фокусируйтесь на нише. Ну и параллельно пополняйте минусовку. Чем больше минус слов соберете, тем больше денег сэкономите.
    Вот собственно и всё. Чем больше дешевых низкочастотников и стоп-слов вы соберете, тем эффективнее и дешевле будет реклама. Обязательно прорабатывайте сопутствующие области. Например для продажи мебели мне с ходу видится посмотреть в сторону "ремонт квартиры", "переезд" и тому подобное.

    Конверсия лэндинга зависит не только от самого лэндинга, но и от соответствия контента до сгиба на лэнде текстам обьявлений и ключевым запросам.

    Если коротко, то как-то так -))
    Ответ написан
    1 комментарий
  • Как реализуется логика дополняющих товаров в интернет-магазине?

    gzhegow
    @gzhegow
    aka "ОбнимиБизнесмена"
    Есть таблица параметров. Есть таблица товаров. Есть таблица товаро-параметров. У текущего товара есть параметры.
    Понятие связанное оно как бы говорит "такие же или плюс минус один", и уже вот эта фраза зашивается в твою страницу на программном коде - что означает плюс минус 1.

    По итогу формируется запрос, который возвращает ID-шки элементов.
    Потом по id-шкам запрашиваются сами элементы.
    Фсо.

    Звони мне в скайп или на емейл пиши, объясню наглядно.
    Ответ написан
    2 комментария
  • Как реализуется логика дополняющих товаров в интернет-магазине?

    R0dger
    @R0dger
    Laravel/Yii/2 AngularJs PHP RESTful API
    Посмотрите как у конкурентов сделано, обычно это статистика но не только по Вашему сайту.. а еще и другим. Потом на основе данных и строятся логика.
    Ответ написан
    Комментировать
  • Как реализуется логика дополняющих товаров в интернет-магазине?

    xmoonlight
    @xmoonlight
    https://sitecoder.blogspot.com
    Дополняющие - это размытое определение.
    Есть: "аксессуары к ", "сопутствующие", "похожие", "с этим товаром также смотрят", "с этим товаром также покупают", "вы уже смотрели", "самое просматриваемое в категории", "новинки категории", "самое покупаемое категории".
    Что интересует?)
    Ответ написан
    8 комментариев
  • Десктопное HTML-приложение без браузера?

    @s2erg
    А чем не устраивает проект nw.js (ранее известный как Node-Webkit)? По-моему, это самый удобный кроссплатформенный вариант. Большое комьюнити, много статей и туториалов, в том числе и на Хабре. Это уже давно не игрушка, красивые десктопные приложения на нём делаются уже и на серьёзном продакшн уровне — например, Spotify, Wunderlist, клиент для Slack, да только один Popcorn Time чего стоит!
    Ответ написан
    Комментировать
  • С помощью какого инструмента/языка программирования можно создать программу с красивым интерфейсом?

    @dmitryKovalskiy
    программист средней руки
    Ваш вопрос по семантике сходен с вопросом - "на каком языке писать самые красивые стихи?". Парадокс - это можно делать на любом. Красивые и удобные интерфейсы делает не язык, а дизайнер интерфейсов,верстальщик и программист. Язык выполняет роль инструмента. Безусловно хренячить красивый GUI на Assembler - задача не тривиальная, но это вопрос выбора инструмента. Вы где хотите интерфейс? В вебе? тогда js-фреймворки наиболее опитмальны. Настолки ? Qt или WinJs/WPF(для Windows-платформы). Мобильная разработка? Xamarin(если сразу писать на все платформы) или целевые фреймворки(Swift, Obj-C) под каждую платформу отдельно.
    Ответ написан
    Комментировать
  • С помощью какого инструмента/языка программирования можно создать программу с красивым интерфейсом?

    Taraflex
    @Taraflex
    Ищу работу. Контакты в профиле.
    c++ + qt qml
    Ответ написан
    Комментировать
  • Laravel. ACL. Загвоздка с логикой работы?

    kaluzhanin
    @kaluzhanin
    Я у себя применял подход, взятый у гема CanCan из RubyOnRails.

    Идея такова: определяем trait Ability и добавляем ему к классу User. Сам этот trait имеет метод can, который разрешает/запрещает определенное действие:

    <?php
    
    trait Ability
    {
        public function can($verb, $noun)
        {
            $class = is_string($noun) ? $noun : get_class($noun);
            if(is_callable([this, "canManage$class"]))
            {
                $this->{"canManage$class"}($verb, $noun);
            } else {
                 $this->fallback($verb, $noun);
            }
        }
    
        public function canManageUser($verb, $noun)
        {
            switch($verb) {
                case 'create':
                    return true;
                case 'edit':
                    if ($this->isAdmin()) return true;
                    if ($noun->id == $this->id)  return true;
                    break;
                case 'delete':
                case 'destroy':
                    if ($noun->id == $this->id) return false;
                    break;
            }
            return $this->fallback($verb, $noun);
        }
    
        public function fallback($verb, $noun)
        {
            if ($this->isAdmin()) return true;
            return false;
        }
    
        public function isAdmin()
        {
            return $this->role == self::ADMIN;
        }
    }


    Таким образом мы изолируем семантику ролей в одном конкретном месте, и определяем разрешения не на уровне класса Сущностей, а на уровне конкретной сущности, что гораздо гибче.

    Что касается использования в view, то никаких проблем:
    @if(Auth::user() && Auth::user()->can('edit', $page))
    <form></form>
    @endif
    @if(Auth::user() && Auth::user()->can('create', 'Page'))
    <a href="#">Добавить страницу</a>
    @endif
    Ответ написан
    Комментировать
  • Что такое полиморфные связи?

    greabock
    @greabock
    Могу
    Предположим, что у Вас есть комментарий, который может относится к посту(пользователя), а может относится к статье блога.
    тогда у Вас таблица может выглядеть примерно так:
    comment_id | parent_id | morph| comment_content | author

    где:
    comment_id - идентификатор самого коммента
    parent_id - идентификатор сущности к которой он относится
    morph - тип сущности, к которой относится этот комментарий.
    comment_content, author - тут я думаю понятно
    тогда записи могут выглядеть так:
    comment_id | parent_id | morph   | comment_content | author
    ---------------------------------------------------------------
      1        |   1       | post    | бла бла бла     | vasya
    ---------------------------------------------------------------
      2        |   1       | article | бла бла бла     | vasya
    ---------------------------------------------------------------

    при чем, несмтря на то, что parent_id у них одинаковый, в первом случае он относится к id в таблице post, а во втором к article
    Это и называется полиморфической связью.

    пример приведу на фреймворке laravel для php (но ORM там очень схож с Rails, так-что проблем возникнуть не должно)
    Модель комментария будет выглядеть приблизительно так:

    class Comment extends Eloquent {
    
     public function morph()
      {
         return $this->morphTo();
      }
    
    }

    а модели поста и статьи:

    class Post extends Eloquent {
    
      public function photos()
      {
        return $this->morphMany('post', 'morph');
      }
    
    }

    class Article extends Eloquent {
    
      public function photos()
      {
        return $this->morphMany('article', 'morph');
      }
    
    }

    вроде бы ничего не напутал...
    Ответ написан
    1 комментарий
  • Что такое полиморфные связи?

    Fesor
    @Fesor
    Full-stack developer (Symfony, Angular)
    habrahabr.ru/post/79431 - читаем и осознаем примеры.

    По сути это все тоже старое доброе наследование, когда у нас несколько типов записей хранятся в одной таблице и разделаются полем type. Можно в нескольких таблицах хранить и общие поля в базовую таблицу выносить... суть примерно в этом.
    Ответ написан
    4 комментария
  • VPS. Каковы особенности работы?

    HeadOnFire
    @HeadOnFire
    PHP, Laravel & WordPress Evangelist
    В целом @inkvizitor68sl все толково написал, я бы лишь добавил:
    1. Новичку, возможно, есть смысл начать не с Debian, а с Ubuntu 12.04. По нему в сети тьма уроков и информации на всех языках мира, так что порог входа будет легче. А по мере того, как станете матерым юниксоидом, ничто не мешает перейти на Debian либо то, что Вам лично уже будет по душе - к тому моменту сами будете для себя это понимать. Перенести сайты с одного дроплета на другой - вопрос нескольких минут.
    2. По поводу файрвола. Я у себя через iptables закрыл все нах, оставив только http, ssh и loopback. На DO есть нормальный урок на эту тему.
    3. И по поводу почты. Сделать почту правильно на своем сервере - задачка та еще. Лично я вообще не беру на себя ответственность за клиентскую почту, ибо гемор конкретный (а на VPS у меня не только свои проекты, но и клиентские). Идеальный вариант - Яндекс почта для домена (бесплатно) или аналогичное решение от Google (платно). Плюсы этого подхода очевидны: стабильность, надежность, защищенность, привычный GUI вебмейла, уже готовые приложения для iOS/Android и так далее.
    Ответ написан
    4 комментария
  • VPS. Каковы особенности работы?

    @inkvizitor68sl
    Linux-сисадмин с 8 летним стажем.
    Фактически вам дают выделенный сервер (который просто не является железным, на то он и виртуальный). Если говорить про digitalocean - там у вас действительно всё своё выделенное (память не шарится, а аллоцируется при старте виртуалки, ядро процессора для вас личное на тарифах от $10, lvm-том с только вашей виртуалкой (фактически - выделенный для вас раздел raid-массива)).

    Всеми настройками внутри системы занимаетесь вы. Более того, хостер даже не отвечает за то, что у вас система запустилась. Если виртуалка грузится до биоса - то свою работу по обеспечению работы сервера хостер выполнил (опустим в этом контексте вопросы про сеть). Если сломали ОС и она не загружается - у вас есть кнопка "переустановить чистую систему". За бэкапы, опять же, отвечаете вы (digitalocean предоставляет платные бэкапы, но они не очень удобны). За безопасность - вы.
    В случае с digitalocean у вас есть доступ к "монитору" виртуалки и загрузочный rescue-livecd. В общем-то всё.

    По поводу того, как настраивать (если речь про стандартный стек LAMP), то:
    1) debian 7 x64
    2) отключение авторизации рута по паролю, использование ssh-ключей
    3) для диагностики установить snoopy, настроить логгирование sftp.
    4) не использовать ftp, использовать только sftp. Желательно, по ключам. В sftp-клиенте ни в коем случае не хранить пароли от аккаунта или ssh ключа.
    5) nginx+apache-mpm-itk + php 5.3 и выше + percona-server вместо mysql
    6) в конфигах виртуалхостов включите open basedir, если сайт будет с этой настройкой работать (эта опция запрещает php-скриптам при обращении к ним по http выходить за пределы указанных в basedir каталогов)
    7) не забудьте включить MatchUser/MatchGroup для виртуалхостов
    8) обязательно настроить default host для apache и nginx, чтобы исключить неконтролируемую конфигами обработку каких либо запросов по http. Обычно вешают 403 или 404 ошибку в качестве дефолта.
    9) не ставить лишний софт, не вводить бездумно команды из случайно найденных в гугле мануалов, если не понимаете что именно эта команда делает.
    10) не ставить софт из исходников, особенно из недоверенных источников.
    11) если на сервере нужна исходящая почта, то корректно настроить ограничения для неё. Например, для exim4 (он предпочтителен в Debian) - раз, два.
    12) убрать за http-auth все лишние административные скрипты - phpmyadmin, админки сайтов, графики, мониторинг и так далее.

    Это исключит почти все возможности атаки на сервер снаружи. В такой конфигурации если вас и взломают, то либо из-за украденного пароля/ключа, либо поломают сам сайт и зальют вредоносные файлы через php-скрипты непосредственно сайта.
    Более того, у меня в такой конфигурации пока не сломали ни одну виртуалку целиком (были проблемы с заражением отдельных сайтов, конечно - но это было сделано явно через php), несмотря на разрешающий всё firewall и стандартный ssh-порт.

    А вообще за настройку всего этого добра под 2-3 сайта админы берут около 500 рублей.
    Ответ написан
    42 комментария
  • Как реализовать фасетный поиск?

    nikel303
    @nikel303
    1. Берете характеристики товаров, которые могу участвовать в фильтре, получаете для каждой характеристики все варианты значений для текущей выборки товаров.
    2. Выводите в форму фильтра, значения сгруппированные по характеристикам с инпутом-checkbox.
    3. Пользователь ставит галки, отправляет форму.
    4. Формируете критерий для выборки из базы на основе запроса.
    5. Переходим к пункту 1.

    Для ускорения: индексы, кэш, sphinx
    Ответ написан
    3 комментария
  • MySQL. В чем отличие INNER от CROSS JOIN?

    Rsa97
    @Rsa97
    Для правильного вопроса надо знать половину ответа
    JOIN, INNER JOIN и CROSS JOIN в случае MySQL синтаксически эквивалентны.
    Ответ написан
    Комментировать
  • MySQL. Что происходит с индексами при вставке данных в таблицу с индексами?

    mgyk
    @mgyk
    1) Да. Не сильно зависит от размера таблицы. Время на обновление индекса примерно одинаковое на каждую запись. Данные можно читать и писать, залочена будет только текущая запись (INNODB) или будет залочена вся таблица (MYISAM) до того момента как все запишется.
    2) Для индексированной строки - на запись меняется индекс.

    Вставка в таблицу с индексами медленнее, чем без. Если нужно вставлять большими кусками по милиону записей и больше, можно выключить индексы, вставить данные, а потом включить.

    ALTER TABLE DISABLE KEYS
    INSERT INTO xxx VALUES (1,2,3)
    ALTER TABLE ENABLE KEYS

    В 99% это не нужно, достаточно вставлять данные большими кусками c помощью
    INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9); что уже даст очень приличный прирост скорости
    Ответ написан
    Комментировать
  • MySQL. Как поддерживать ссылочную целостность при наличии связи многие-ко-многим?

    Rsa97
    @Rsa97
    Для правильного вопроса надо знать половину ответа
    Многие-ко-многим реализуется через таблицу отношений. Каждая из двух таблиц сущностей имеет с таблицей отношений связь один-ко-многим. Если удалить запись из одной из таблиц сущностей, то в таблице отношений удалятся соответствующие записи связи.
    Ответ написан
    5 комментариев