[#boost-urls-url_base-set_params] = xref:boost.adoc[boost]::xref:boost/urls.adoc[urls]::xref:boost/urls/url_base.adoc[url_base]::set_params :relfileprefix: ../../../ :mrdocs: Set the query params == Synopsis Declared in `<https://www.github.com/boostorg/url/blob/develop/include/boost/url/url_base.hpp#L2278[boost/url/url_base.hpp]>` [source,cpp,subs="verbatim,replacements,macros,-callouts"] ---- xref:boost/urls/url_base.adoc[url_base]& set_params( std::initializer_list<xref:boost/urls/param_view.adoc[param_view]> ps, xref:boost/urls/encoding_opts.adoc[encoding_opts] opts = {}) noexcept; ---- == Description This sets the query params to the list of param_view, which can be empty. An empty list of params is distinct from having no params. Reserved characters in the string are percent‐escaped in the result. === Example [,cpp] ---- assert( url( "http://example.com" ).set_params( {"id", "42"} ).query() == "id=42" ); ---- === Postconditions [,cpp] ---- this->has_query() == true ---- === Exception Safety Strong guarantee. Calls to allocate may throw. === Complexity Linear. === BNF [,cpp] ---- query = *( pchar / "/" / "?" ) query-param = key [ "=" value ] query-params = [ query-param ] *( "&" query-param ) ---- === Specification * link:https://datatracker.ietf.org/doc/html/rfc3986#section-3.4 >3.4. Query (rfc3986) @li