powered by simpleCommunicator - 2.0.51     © 2025 Programmizd 02
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Видимость внутри функции переменных
25 сообщений из 50, страница 2 из 2
Видимость внутри функции переменных
    #39699759
Фотография Андрей159
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудух,
Удиви хоть чем-то. Пока что одни оскорбления. Ты ничего не должен доказывать. Нет времени на тебя. Веселись дальше.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699766
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Андрей159Когда функция в функции, то нужно дважды объявить. Во внешней функции и во внутренней. Иначе никак.Ну почему сразу "никак"? Можно использовать для хранения/передачи данных любой суперглобальный массив. Оно всяко понятнее "глобализации".

ИМХО если подходить с точки зрения парадигмы функционального программирования, то global есть банальный костыль. Без него вполне можно обойтись, передавая переменную по ссылке через параметр вызова функции.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699773
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Андрей159API Google, Facebook, VK, OK, Instagram освоите - это только один из 10 нужных пунктиков.Для сшибания бабла - возможно, будет где-то полезным. Для понимания и наработки опыта как программисту в классическом понимании - почти никакой пользы. Это как купить в магазине полочку и прибить ее парой гвоздей к стене. Полочка будет в доме, конечно, но создавать ее Вы не умеете. Конечно, я не призываю всех всё делать руками. Кому-то нравится и галочки в Битриксе тыкать.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699848
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleИМХО если подходить с точки зрения парадигмы функционального программирования, то global есть банальный костыль. Без него вполне можно обойтись, передавая переменную по ссылке через параметр вызова функции.
в его случае вызов файла идёт ИЗ функции, так что там этот номер не пройдёт, если хочется именно глобальную переменную. Т.е. у всего файла область видимости ограничивается этой ф-ей. В итоге там получилась сложная запутанность.
Для таких случаев были придуманы классы, которые в умелых руках творят чудеса и позволяют даже таким лопухам разобраться в коде мастера и через год.

Кстати, если будет вереница ф-й, то в каждую кидать эту переменную (а их ведь может быть несколько) вызовет жгучую боль в области геморроя, потому что совершенно не ясно, что с переменной происходило "где-то там, неизвестно где".
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699857
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудухvkleИМХО если подходить с точки зрения парадигмы функционального программирования, то global есть банальный костыль. Без него вполне можно обойтись, передавая переменную по ссылке через параметр вызова функции.
в его случае вызов файла идёт ИЗ функции, так что там этот номер не пройдёт, если хочется именно глобальную переменную.В данном случае в наличии имеется банальнейший бардак. А именно, растусовка элементов одной сущности по разным сущностям другого рода. Конкретно, функция перестала быть единым целым и разошлась по разным файлам. Не криминально, но и код весьма не очевиден для понимания. Вот попытка собрать паззл, да ещё и не понимая, как работает штатный сборщик паззлов, окончилась неудачей. Сомневаюсь, что при рассматриваемом подходе костыль в виде второго глобала принесет какую-то практическую пользу.

Если уж очень хочется иметь динамически изменяющуюся функцию и при этом по какой-то причине категорически не хочется использовать ООП, то совсем не обязательно городить огород с инклюдами, можно посмотреть на лямбда-функции, они же, анонимные. Можно, наконец, хоть из кусочков по ситуации сконструячить функцию как текст и eval'нуть его.

полудухДля таких случаев были придуманы классы, которые в умелых руках творят чудесаНаверно, Вам повезло с умелыми руками. Не нарывались на классы, где в метод передается с десяток параметров? А когда какие-нить классы Catalog, Categories, Basket наследуется прямиком от Database, а тот, в свою очередь, от Settings... что хотел сказать автор методом select_all() - поди ж угадай сразу, что оно возвращает массив всех записей по SQL-запросу, а вовсе не полный список товаров в корзине... Жаловались на "не работает периодически" - когда разбираться стал, вышло, что скрипт по нескольку соединений к базе открывает и упирается в лимит для пользователя СУБД когда на сайт народ набегает.

В общем, чего хотел сказать то. Когда в голове каша - любую технологию испоганить можно так, что порой проще переписать кусок с нуля, чем поддерживать как есть. И классы в том числе.

полудухКстати, если будет вереница ф-й, то в каждую кидать эту переменную (а их ведь может быть несколько) вызовет жгучую больНу как сказать... Мое сугубо личное мнение, конечно. Чтоб изолировать от основного скрипта такие вот переменные для прямой передачи из одной функции в другую, вполне можно использовать суперглобальный массив $GLOBALS. Там отдельные массивы "по темам". Конечно, его элементы и применяемость следует расписать где-то в доке, чтоб не нарваться на неприятности. Вряд ли порекомендую этот способ для разработки с нуля, но для поддержки чего-то старенького вполне годится.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699869
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleНе нарывались на классы, где в метод передается с десяток параметров? А когда какие-нить классы Catalog, Categories, Basket наследуется прямиком от Database, а тот, в свою очередь, от Settings... что хотел сказать автор методом select_all() - поди ж угадай сразу, что оно возвращает массив всех записей по SQL-запросу, а вовсе не полный список товаров в корзине...
давно уже не нарываюсь ни на что, у меня свой фреймворк с нормальным ООП )
в правильном ООП в метод не должно передаваться куча параметров, делая снаружи метод совершенно непредсказуемым. Должно быть несколько методов, в названии которых и фигурируют разные параметры.
Чем проще метод, тем лучше. 1-3 -строчные методы в идеале.

Глобалы в ООП тоже отваливаются сами. После загрузки настроек приложения никакие глобалы уже не нужны ;)
А сейчас уже на next lvl перебираюсь - C++
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699874
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудухдавно уже не нарываюсь ни на что, у меня свой фреймворкНа поддержку что-то чужое принципиально не берете? ;-)

полудухв правильном ООП в метод не должно передаваться куча параметров, делая снаружи метод совершенно непредсказуемым.Ага, вот ишшо б это каждый понимал.

полудухЧем проще метод, тем лучше. 1-3 -строчные методы в идеале.Да ну! И что в эти 1-3 строчки запихаете - вызов функии, с кучей параметров и реализацией бизнес-логики на пару страниц кода?
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699877
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkle, БЛ точно так же распихивается по разным классам и методам, т.к. она кусками очень даже воспроизводима повторно.
будь это сабмит форм, рисование графиков, парсинг лидов, итп

главное правило заключается не в 1-3 строках, а в том, чтобы метод выполнял 1 задачу, а не винегрет выдавал.
так что если даже там будет if/switch с набором методов, они читаемость не уменьшат
а вот в этих методах уже легко можно уложиться в 1-3 строчки
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699878
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleполудухдавно уже не нарываюсь ни на что, у меня свой фреймворкНа поддержку что-то чужое принципиально не берете? ;-)
пишу CRMы на заказ
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699880
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудухчтобы метод выполнял 1 задачу, а не винегрет выдавалБанальная, вроде, задача: проверить данные с формы перед записью в базу, сформировать при необходимости список ошибок. Метод изначально пустой, переопределяется в зависимости от конечного класса (клиент, проект, таск, лог, контакт и т.п.), где необходимо проверять от одного до более десятка параметров. В ряде случаев необходимо свериться со смежными сущностями. Например, дата планового окончания таска не должна превышать дату завершения проекта, а дата окончания субтаска (таковой определяется по данным в поле task_parent), соответственно, финальную дату родительского таска.
Есть винегрет? На мой взгляд, нету. А кода до пары страниц в зависимости от.
Вы как-то это распихаете в означенные Вами строчки?
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699899
Дмитрий Мух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleполудухчтобы метод выполнял 1 задачу, а не винегрет выдавалБанальная, вроде, задача: проверить данные с формы перед записью в базу, сформировать при необходимости список ошибок. Метод изначально пустой, переопределяется в зависимости от конечного класса (клиент, проект, таск, лог, контакт и т.п.), где необходимо проверять от одного до более десятка параметров. В ряде случаев необходимо свериться со смежными сущностями. Например, дата планового окончания таска не должна превышать дату завершения проекта, а дата окончания субтаска (таковой определяется по данным в поле task_parent), соответственно, финальную дату родительского таска.
Есть винегрет? На мой взгляд, нету. А кода до пары страниц в зависимости от.
Вы как-то это распихаете в означенные Вами строчки?
Он про SOLID вещает походу.

Типа класс ClientController принимает данные с формы, ClientModelBinder биндит их на ClientModel, ClientValidator проверяет и формирует при необходимости список ошибок,
ClientService отвечает за бизнес-логику, а ClientRepository за запись в базу.

Возможны вариации, но как-то так всё разложено согласно принципу единственности отвественности.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699933
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleполудухчтобы метод выполнял 1 задачу, а не винегрет выдавалБанальная, вроде, задача: проверить данные с формы перед записью в базу, сформировать при необходимости список ошибок. Метод изначально пустой, переопределяется в зависимости от конечного класса (клиент, проект, таск, лог, контакт и т.п.), где необходимо проверять от одного до более десятка параметров. В ряде случаев необходимо свериться со смежными сущностями. Например, дата планового окончания таска не должна превышать дату завершения проекта, а дата окончания субтаска (таковой определяется по данным в поле task_parent), соответственно, финальную дату родительского таска.
Есть винегрет? На мой взгляд, нету. А кода до пары страниц в зависимости от.
Вы как-то это распихаете в означенные Вами строчки?
вот вам пример, как обычно пишут БЛ:
Код: php
1.
2.
3.
4.
5.
6.
if (i == 0)
    b[i] = (a[i] + a[i+1]) / 2.0;
else if (i == N-1)
    b[i] = (a[i] + a[i-1]) / 2.0;
else
    b[i] = (a[i] + a[i+1] + a[i-1]) / 3.0;


я пишу так:
Код: php
1.
2.
3.
if      (i == 0)        {b[i] = (a[i]   + a[i+1])   / 2.0;}
else if (i == N-1)      {b[i] = (a[i]   + a[i-1])   / 2.0;}
else                    {b[i] = (a[i]   + a[i+1]   + a[i-1])   / 3.0;}


и строчек 3, а не 6, и читаемость получше за счёт форматирования.

авторНапример, дата планового окончания таска не должна превышать дату завершения проекта, а дата окончания субтаска (таковой определяется по данным в поле task_parent), соответственно, финальную дату родительского таска.
Есть винегрет?
ещё как есть, вон он, розовенький такой, угловатый...
ну во1, формы всё-таки стоит разбивать на табы (именно в бэкенде, а не в таблице. Таблица одна), чтобы юзер засылал кусочек, а не все 80 полей (у меня и такие есть)
Т.е. тут ещё архитектура упрощает БЛ.
во2, те условия, которые не получается запихать в массив с формой (который жуёт валидатор форм), их можно распихать по отдельным методам, решающим конкретную задачу. Например, "сравнение дат" производится в Date::cmp_two($date1, $date2).

авторВы как-то это распихаете в означенные Вами строчки?
распихаю в означенные мной однозадачные методы ;)
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699935
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий МухВозможны вариации, но как-то так всё разложено согласно принципу единственности отвественности.
одна из основ ООП ;)
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699940
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудухну во1, формы всё-таки стоит разбивать на табы (именно в бэкенде, а не в таблице. Таблица одна), чтобы юзер засылал кусочек, а не все 80 полейПри чем тут табы? Юзер уже все поля заполнил, их значения очищены от возможного мусора и сохранены в экземпляре класса как свойства. Настало время проверки данных.

полудухНапример, "сравнение дат" производится в Date::cmp_two($date1, $date2).Ну а даты откуда возьмутся? Одна пришла из формы, это понятно. Вторая - ?

полудухя пишу так:
Код: php
1.
2.
3.
if      (i == 0)        {b[i] = (a[i]   + a[i+1])   / 2.0;}
else if (i == N-1)      {b[i] = (a[i]   + a[i-1])   / 2.0;}
else                    {b[i] = (a[i]   + a[i+1]   + a[i-1])   / 3.0;}



и строчек 3, а не 6, и читаемость получше за счёт форматирования.Не принципиально. К тому же, без синтаксической подсветки кода читаемость структуры сильно теряется.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699941
Фотография Андрей159
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мне нравятся классы. Точнее нравится как редактор оформляет код и подсказывает. А значит все дело в любви к редакторе, а не к классам. Если редактор усовершенствуется и будет больше подсказывать, то наверняка не будут так тратить время на обертку простейшего кода в класс.

Классы использую только по назначению. С ними падает быстродействие (не знаю как дела с PHP 7,2, но по производительности далеко до JS). Встречал движки сделаны как конфетка снаружи, а внутри без стопки мануала не разобрать. Все функции по 20 раз вложены друг в друга классами. Одну фичу прикрутить было мучением. Все основано на событиях, а те в свою очередь все части блоков куда-то кешировали. Не зная что вызвать - ничего визуально не изменялось, хоть напрямую делал изменения - сайт работал дальше на своей волне пока не происходило событие UPDATE в классе. Где его искать - не было особо времени. Я сделал внешнюю затычку и все работало без издеваний над чужим кодом. Но сайт все время умирал и мучался не выдерживая даже 10 одновременных запросов поиска. Весьма извесный движок ImageCMS на КодекНайтере. В итоге разработчики заявили что скоро перейдут на новый движок. И через год перешли. Угадайте какой на какой движок ??? ВордПрес.))) Нитернет-магазин... Отошел от темы...

Классы - для множественного использования учитывая индивидуальную внутреннюю жизнь в классе. Если кратко, то салютировать разноцветными частицами в рандомных направлениях это задания для классов. Делаем выстрел (активируем класс) - полет каждой частицы просчитает класс. А поручить одно задания без каких либо потом дополнительных обращений - это для функции.

Переделал часть каталога в интернет магазин. Был не готов к монетизации, пришлось доделать "предложение сайта", "счет/оплата", "история (хронология событий)". Сейчас для стимулирования осталось подкрутить "задания" и награждать дополнительным рейтингом.
"История" небольшая функция, которая находит разницу и ведет журнал изменений/дополнений/удалений. Легко отследить по следам и по необходимости вернуть обратно или поправить. В этой функции подвязал проверку "задания"

Так случилось что все этапы разработки были простыми. Все чего боятся другие я использую с легким понимаем. Тот же GOTO совсем не смертельный, а наоборот много упрощает (конечно же одиночный случай). Рекурсия также используется для чтения до 7ми уровневого вхождения по таблицам при компилировании страниц конструктора "прайс-соглашение". Все всегда просто. А тут заштопорило на костыле global...
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699943
Фотография Hett
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудухвот вам пример, как обычно пишут БЛ:
Код: php
1.
2.
3.
4.
5.
6.
if (i == 0)
    b[i] = (a[i] + a[i+1]) / 2.0;
else if (i == N-1)
    b[i] = (a[i] + a[i-1]) / 2.0;
else
    b[i] = (a[i] + a[i+1] + a[i-1]) / 3.0;





Нет, обычно пишут так:
Код: java
1.
2.
3.
4.
5.
6.
7.
if (i == 0) {
    b[i] = (a[i] + a[i+1]) / 2.0;
} else if (i == n-1) {
    b[i] = (a[i] + a[i-1]) / 2.0;
} else {
    b[i] = (a[i] + a[i+1] + a[i-1]) / 3.0;
}



Если уж придерживаться всех рекомендаций по формлению кода.


полудухя пишу так:
Код: php
1.
2.
3.
if      (i == 0)        {b[i] = (a[i]   + a[i+1])   / 2.0;}
else if (i == N-1)      {b[i] = (a[i]   + a[i-1])   / 2.0;}
else                    {b[i] = (a[i]   + a[i+1]   + a[i-1])   / 3.0;}


и строчек 3, а не 6, и читаемость получше за счёт форматирования.



Да запишите тогда уж в одну строку, если дело в их количестве. Но это лишь частный случай, когда ваш стиль возможно и смотрится проще, но в любой адекватной команде вам так писать не дадут. Пишите в одного проекты?
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699945
Фотография Андрей159
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
[quot полудух]я пишу так:
Код: php
1.
2.
3.
if      (i == 0)        {b[i] = (a[i]   + a[i+1])   / 2.0;}
else if (i == N-1)      {b[i] = (a[i]   + a[i-1])   / 2.0;}
else                    {b[i] = (a[i]   + a[i+1]   + a[i-1])   / 3.0;}



мда..

я сделал свой прекомпилятор и испольую вот такие теги
Код: php
1.
2.
3.
4.
5.
/*[copy=001]*/
# Код PHP
# Код PHP
# Код PHP
/*[/copy]*/


При сохранении кода в PHPШторм редакторе вызывается мой прекомпилятор.
Во первых он убирает все комментарии учитывая всевозможные нюансы с " ' ` {}
2. Если находит тег [copy= и обнаружит что код был изменен, то произведет замену во всех файлах, где есть тот же [copy=001]
3. Отправит на сервер по FTP все измененные файлы
Если нужно вставить копию кода в новый php файл то используется {copy=001} который автоматически будет заменен после инициализации.
На сервере будет только чистый компактный код
Очень удобно. Ведь есть много повторений например в том же addnews.php, editnews.php, интерактивные/addnews.php, интерактивные/editnews.php
Также там есть более сложный алгоритм, который запись HTML копирует как PHP значение, которое можно потом использовать.
Сам прекомпилятор это отдельная программа, которая запускается с параметром от PHPШторм. Если просто запустить, то можно посмотреть все участки "copy" кодов, а также запросить новый номер.

Чем еще хороша программа. Можно работать как шаблоном. Можно заниматься несколькими проектами одновременно, если сайты очень похожи начинкой. Любое усовершенствование на одном сайте улучшит автоматически все связанные сайты. Удобства никакого нет, а вот экономится время очень.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699975
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleПри чем тут табы?при том, что вам не нужно обрабатывать 80 полей за раз, а лишь 10.

полудухНапример, "сравнение дат" производится в Date::cmp_two($date1, $date2).Ну а даты откуда возьмутся? Одна пришла из формы, это понятно. Вторая - ?
Ну это же ваш пример. Найдите там себе свою вторую дату:
авторНапример, дата планового окончания таска не должна превышать дату завершения проекта , а дата окончания субтаска (таковой определяется по данным в поле task_parent), соответственно, финальную дату родительского таска .

Не принципиально. К тому же, без синтаксической подсветки кода читаемость структуры сильно теряется.вам видимо показалось, что я здесь чтобы спорить с вами об очевидных вещах )
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39699983
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудухvkleПри чем тут табы?при том, что вам не нужно обрабатывать 80 полей за раз, а лишь 10.Речь идет о сущности в целом, а не об отдельных полях.

полудухНу это же ваш пример. Найдите там себе свою вторую дату:
авторНапример, дата планового окончания таска не должна превышать дату завершения проекта , а дата окончания субтаска (таковой определяется по данным в поле task_parent), соответственно, финальную дату родительского таска .Именно. Ключевое слово "найдите". Т.е. вымутить еще несколько строк кода для создания экземпляра сущности, загрузки в объект данных с заданным айди из базы, и только тогда искомая дата станет доступна. Четвертой только строчкой можно приступить к сравнению, пятой сформировать ошибку. Удачи Вам в Ваших трехстрочных методах! Мы уж, как-нибудь, по рабоче-крестьянски.


полудухвам видимо показалось, что я здесь чтобы спорить с вами об очевидных вещах )Нет. Просто я не приемлю код-лапшу. Глаза, знаете-ли, устают от него. :)
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39700007
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
vkleполудухпропущено...
при том, что вам не нужно обрабатывать 80 полей за раз, а лишь 10.Речь идет о сущности в целом, а не об отдельных полях.
вовсе нет, такого условия не стоит. Никто не требует за раз зохавать ВСЕ поля в форме.
и юзеру, и разрабу удобнее работать со сгруппированными однотипными порциями: персональные данные, био, предпочтения, документы, итд.

полудухНу это же ваш пример. Найдите там себе свою вторую дату:
пропущено...
Именно. Ключевое слово "найдите". Т.е. вымутить еще несколько строк кода для создания экземпляра сущности, загрузки в объект данных с заданным айди из базы, и только тогда искомая дата станет доступна. Четвертой только строчкой можно приступить к сравнению, пятой сформировать ошибку. Удачи Вам в Ваших трехстрочных методах! Мы уж, как-нибудь, по рабоче-крестьянски.
спор ради спора
вы сейчас говорите о способах валидации юзерского ввода, а не о парадигме ООП.
т.е. начали мы тут про здравие, но вас всё тянет на упокой...
метод решает 1 задачу. Точка.
в идеале 1-3 строчки. А может и 5. А если там SQL-запрос, то может быть и целый экран.
Будет он там тащить данные из БД или считать чего-то - дело десятое. Главное, чтобы задача была одна.

В вашем случае я бы условия вообще закэшировал при создании формы, если время проекта не может измениться, пока юзер форму сабмитит.
Но также обычно не будет проблемы дёрнуть из БД (конечно же в отдельном методе) или во время INSERT/UPDATE чекнуть через CASE.
В итоге никаких винегретов и через год этот код будет всё так же читаем и понятен даже студенту.

авторТ.е. вымутить еще несколько строк кода для создания экземпляра сущности
вообще-то этим spl_autoload занимается... и методы там static::
авторпо рабоче-крестьянски
крестьяне опять что-то новое изобрели? )

полудухвам видимо показалось, что я здесь чтобы спорить с вами об очевидных вещах )Нет. Просто я не приемлю код-лапшу. Глаза, знаете-ли, устают от него. :)
что ещё за лапша?
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39700011
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудух,

Речь идет о валидации объекта с множеством данных. Метод check() должен вернуть либо "годен", либо "найдены ошибки". Ни больше и не меньше. Мы совершенно о разных о разных вещах говорим, очевидно.
Продолжайте думать о формах, если Вам так угодно.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39700116
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
мы говорим вот об этом
полудухvkleНе нарывались на классы, где в метод передается с десяток параметров? А когда какие-нить классы Catalog, Categories, Basket наследуется прямиком от Database, а тот, в свою очередь, от Settings... что хотел сказать автор методом select_all() - поди ж угадай сразу, что оно возвращает массив всех записей по SQL-запросу, а вовсе не полный список товаров в корзине...
давно уже не нарываюсь ни на что, у меня свой фреймворк с нормальным ООП )
в правильном ООП в метод не должно передаваться куча параметров, делая снаружи метод совершенно непредсказуемым. Должно быть несколько методов, в названии которых и фигурируют разные параметры.
Чем проще метод, тем лучше. 1-3 -строчные методы в идеале.
vkleДа ну! И что в эти 1-3 строчки запихаете - вызов функии, с кучей параметров и реализацией бизнес-логики на пару страниц кода?
а куда вас теперь унесло в попытках что-то доказать я без понятия.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39700128
vkle
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
полудух,

Пока что Вы пытаетесь кому-то что-то доказать, притом, почему-то не в тему. Такое обычно бывает у политиков, когда по делу сказать им нечего.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39701019
Фотография Андрей159
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Все-таки переделал по быстрому все на два класса))) Запутался с объявлениями и стало не весело.

Сделал реактивный запуск
Код: php
1.
2.
3.
4.
5.
6.
7.
8.
function kas_autoload($className){
    $classPath = explode('_', $className);
	if($classPath[0]!='KAS')return;
    if(count($classPath)>3)$classPath=array_slice($classPath,0,3);
    $filePath = ENGINE_DIR.'/classes/'.implode('/',$classPath).'.php';
	require_once $filePath;#if(file_exists($filePath))
}
spl_autoload_register('kas_autoload');



Очень удобно и не нужно ничего помнить в дальнейшем

Вызов с любого места к примеру:
Код: php
1.
2.
 $tsk = new KAS_task('g2i2');
 $tsk->save_task_and_event_SELECTED( 'tasks', 'ok' );


Класс KAS_task подключается require_once автоматически. За это отвечает spl_autoload_register и функция kas_autoload. И как я хотел загружается только по необходимости.

На счет global, то вывод такой:
1. global
2. require_once
а не наоборот

При трассировки кода получалось, что загружалось require_once, но до этого global не было, а было внутри файла, тоесть после require_once.
...
Рейтинг: 0 / 0
Видимость внутри функции переменных
    #39701072
Фотография полудух
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
там не нужен _once, он дорогой
Код: php
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
spl_autoload_extensions('.php');
spl_autoload_register('autoload_classes');

function autoload_classes($class)
{
    // $class = core\Support\Autoload,    а чтобы открыть файл нужен: .core12345/Support/Autoload.php
    $class = strtr(
        $class,
        array(
            'core\\'    => core\A::$dir['CORE'],
            'app\\'     => core\A::$dir['APP'],
            '\\'        => '/'
        )
    );

    require("{$class}.php");
}


в классах пишется:
Код: php
1.
<?php namespace core\somedir
...
Рейтинг: 0 / 0
25 сообщений из 50, страница 2 из 2
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Видимость внутри функции переменных
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]