Actions

ExpressionScript Engine - Quick start guide/bg: Difference between revisions

From LimeSurvey Manual

(Created page with "<center>File:tailoring9.jpg</center>")
(Created page with "<div class="simplebox">Файл:help.png '''Забележка:''' Динамичното приспособяване може да не работи, ако опциит...")
Line 127: Line 127:




<div class="simplebox">[[File:help.png]] '''Note:''' Dynamic tailoring may not work if answer options are made available in select boxes on the same question page. This results from the fact that tailoring inserts a <nowiki><span></nowiki> tag which is not valid inside select options.</div>
<div class="simplebox">[[Файл:help.png]] '''Забележка:''' Динамичното приспособяване може да не работи, ако опциите за отговор са налични в полетата за избор на същата страница с въпроси. Това се дължи на факта, че шивашките вложки a<nowiki></nowiki> <span>таг, който не е валиден в опциите за избор.</span>


The BMI report looks like this:
The BMI report looks like this:

Revision as of 10:36, 23 November 2023


Ръководство за бърз старт

В рамките на LimeSurvey можете допълнително да персонализирате анкетите си чрез използването на ExpressionScript (накратко: ES). Странична бележка: „ExpressionScript беше наречен Expression Manager (EM) в по-ранна версия. Ако сте чели някъде Expression Manager, това е просто старото име на ES."

ES може да се използва за указване на следното:

  1. Навигация/Разклоняване - позволява на отговорите на респондента да променят реда, в който се показват въпросите;
  2. Скрояване/Разклоняване - помага ви да формулирате въпроса (като препращане към предишни отговори или свързване на изречения въз основа на възрастта или пола на вашите субекти) или как да генерирате персонализирани отчети (като оценки за оценка или персонализирани съвети);
  3. Валидиране - гарантира, че отговорите преминават определени критерии, като минимални и максимални стойности или определен модел на въвеждане.

ES предоставя интуитивен начин за определяне на логиката за всяка от тези функции. Почти всичко, което можете да напишете като стандартно математическо уравнение, е валиден израз.

В момента ES предоставя достъп до 70 функции и може лесно да бъде разширен, за да поддържа повече. Той също така ви позволява да осъществявате достъп до вашите променливи, като използвате четими за човека имена на променливи (вместо SGQA имена).

Предстоящите раздели показват основните места, където се използва ES.


Уместност (Контролиране на навигация/разклоняване)

Някои проучвания използват „Goto Logic“, така че ако отговорите на Въпрос 1 с опция C, ще бъдете пренасочени към Въпрос 5. Този подход е много ограничен, тъй като е трудно да се потвърди. Освен това лесно се разваля, когато трябва да пренаредите въпросите. От друга страна, ES използва булеви уравнения за релевантност, за да посочи всички условия, при които даден въпрос може да е валиден. Ако въпросът е уместен, той се показва, в противен случай не е приложим и стойността „NULL“ се съхранява в базата данни.

Забележка: Това е подобно на това, което може да се направи чрез Редактор на условия, но ES ви позволява лесно да зададете много по-сложни и мощни критерии (и ви позволява да използвате името на променливата вместо SGQA идентификатори).




За да разберем по-добре концепцията за уместност, нека се съсредоточим върху следното проучване, което изчислява индекса на телесна маса (ИТМ) на респондентите в проучването. За да го изтеглите, щракнете върху следната връзка: Пример за изследване на индекса на телесна маса.

Уравнението за релевантност е показано по-долу в колоната Релевантност след името на променливата. Стойностите за релевантност на теглото, теглото_единици, височината и височината са всички 1 (стойност по подразбиране), което означава, че тези въпроси винаги се показват. Уместността за ИТМ обаче е {!is_empty(height) и !is_empty(weight)}, което означава, че ИТМ ще бъде изчислен само ако субектът въведе стойност както за височината, така и за теглото (по този начин се избягва рискът от получаване на нулева грешка ). Освен това въпросът „Отчет“ се показва само ако респондентът отговори на четирите основни въпроса (височина, единици за височина, тегло, единици за тегло).



Файл:help.png Забележка: Изображението по-горе идва от логически файл на анкетата, който ви позволява да търсите синтактични грешки, преди да активирате анкетата.


Уместността се показва и може да се редактира, когато:

  • искате да видите/редактирате уместността на ниво въпрос
  • искате да видите/редактирате уместността на ниво група


Преглед/редактиране на уместност на ниво въпрос

Това уравнение изчислява индекса на телесна маса (ИТМ). Пита се само дали човекът въвежда ръста и теглото си.



Това е екранът за редактиране на въпроса "ИТМ".



Обърнете внимание, че не използвате фигурните скоби, когато въвеждате уравнение за релевантност.


Преглед/редактиране на уместност на ниво група

Нека сега се съсредоточим върху друг пример - просто проучване от преброяване. За да го изтеглите, щракнете върху следната връзка: Пример за проучване при преброяване.

Първата страница пита колко души живеят с вас и съхранява това в променливата "cohabs". Тази страница се показва само ако имате повече от един съжител (показва се за втория съжител с вас). Също така, p2name, p2age. p2sum се показват само ако въпросът преди всеки от тях съдържа отговор.



Така че групата също има критерии за уместност на ниво въпрос, така че някои въпроси се появяват само ако сте отговорили на определени въпроси преди тях (напр. p2age се показва, ако е отговорено p2name). ES съчетава уместността на ниво група и въпрос за вас. 'Въпроси в група се задават само ако групата като цяло е подходяща. След това се задават само подмножеството въпроси в рамките на групата, които са подходящи.

Ето екранната снимка за редактиране на уместността на ниво група на Съжител 2:



Обърнете внимание, че не използвате фигурните скоби, когато въвеждате уравнение за релевантност.

Шиване/Пипинг

ES ви позволява лесно да правите просто и сложно условно шиене. Понякога просто се нуждаете от проста замяна, като да кажете: „Казахте, че сте купили [ продукт]. Какво ви хареса най-много в него?". Понякога имате нужда от условно заместване като " [ Г-н г-жа.] [ LastName], бихте ли искали да попълните нашата анкета?". В този случай искате да използвате "Mr. или г-жа" въз основа на пола на лицето. Друг път се нуждаете от дори по-сложно заместване (като например въз основа на математическо изчисление). ES поддържа всеки от тези типове шиене/тръбопроводи.


Условни уравнения

Примерът с индекса на телесна маса показва способността да се изчисли ИТМ на човек, дори когато му позволявате да въведе своята височина и тегло в две различни единици (cms срещу инчове и kgs срещу lbs):



В този случай теглото kg е {if(weightunits == "kg", тегло, тегло * 0,453592)}. Тази функция "if()" означава, че ако субектът въведе теглото в килограми, използвайте тази стойност, в противен случай умножете въведената стойност (паунда е алтернативата) по 0,453592, за да я преобразувате в килограми. Променливата heightm използва подобен подход за изчисляване на височината на човека в метри (ръст в cms/100), дори ако той е въвел височината си в инчове (1 метър=3,28084 инча).

ИТМ се изчислява като: {теглоkg / (височинаm * височинаm)}.

И накрая, докладът условно приспособява съобщението за субекта, като й казва какво е въвел. (напр. „Казахте, че сте висок 2 метра и тежите 70 кг.“)

В изображението по-долу теглото използва вложени изрази „if()“, за да категоризира лицето като с поднормено тегло до тежко затлъстяване. Можете да видите уравнението му, като проверите логиката му:



От прозореца за редактиране на този въпрос можете да видите две неща:

  1. Tailoring трябва да огради изразите с фигурни скоби
  2. Изразите могат да обхващат няколко реда, ако, както в този случай, искате да улесните четенето на вложена условна логика.



Персонализирани въпроси, отговори и отчети

Файл:help.png Забележка: Динамичното приспособяване може да не работи, ако опциите за отговор са налични в полетата за избор на същата страница с въпроси. Това се дължи на факта, че шивашките вложки a таг, който не е валиден в опциите за избор.

The BMI report looks like this:



Here is the edit window for the same question.



Anything within curly braces is treated as an expression, being syntax-highlighted (color coded) in the prior image. If you have any typos (such as misspelled or undefined variable names or functions), ES would show an error. In our below example:

  • heightunit.shown is an undefined variable name (it is actually heightunits.shown) and
  • "rnd()" is an undefined function (the proper function name is "round()").

In both cases, the errors are located within a red box to make it easier to spot and fix them.



You can also see that you can quickly create complex reports, such as a table of entered values or tailored advice.

Please remember that all tailoring must surround expressions with curly braces so that LimeSurvey knows which parts of the question are free text and which should be parsed by the ExpressionScript engine.


Validation

ES controls how most of the advanced question options work. These control aspects like min/max numbers of answers, min/max individual values, min/max sum values, and checking that entered values match specified string patterns. Any value in one of those fields is considered an expression, so you can have min/max criteria with complex conditional relationships to other questions.

In all of these cases, since the advanced question attribute is always considered an expression, you do not use curly braces when specifying it.

The sample surveys page shows many working examples containing a variety of validation expressions.

ExpressionScript - presentation

To find out more about ExpressionScript and how you can use different expressions to enhance your survey, please click on the following link.